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Indicator/Control 

Module 


Description 

The Indicator/Control module (S-730) contains three switches, 
four indicator lamps, one 60-pin connector, and intermediary 
circuitry. Switch SW1 selects between the internal (INT) or 
external (EXT) clock. Switches SW2 and SW3 activate the 
RESET and MONITOR functions, respectively. The indicator 
lamps Dl, D2, D3, and D4 show the condition of the HALT, 
MONITOR, ICE (in-circuit enable), and POWER functions. 


The three switches and four indicator lamps are all accessible 
for operation (and viewing) from the outside of the ICD, so 
there are no user-serviceable controls or components on this 
module. 
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SIO S-791 Module 

Components Q JA Socket. By connecting different pins with jumpers, this 
socket is used to select either RS-232, current loop, or TTL 
interface for the TERMINAL port. (See "How To Change 
The Interface Settings.") 

(2) JB Socket. Used the same way as the JA socket, but selects 
the interface for the HOST/AUX port. 

( 3 ) TERMINAL Port Line Driver. The standard line driver is an 
SN75188, and is used with RS-232 and current loop interface 
operation. When TTL interface is used, the standard line 
driver must be replaced with an SN7438 line driver. 

@ HOST/AUX Port Line Driver. Functions the same as the TER- 
MINAL port line driver, except controls the HOST/AUX port. 

(5) JA 5/4/3 Power Supply Jumpers. Supplies power to the TER- 
MINAL port line drivers. Pins 3 and 5 supply + 12V to the 
SN75188 line driver (when using RS-232 or current loop in- 
terface), and Pin 4 supplies + 5V to the Sn7438 line driver 
(when TTL interface is used). 

© JB 5/4/3 Power Supply Jumpers. Functions the same as 
JA 5/4/3, but supplies power to the HOST/AUX port line 
driver. 

® DSW3 Transmission Format Switch. Sets the data format 
and stop bits for the TERMINAL port. (See "How To Set The 
Transmission Format Switches.”) 

© DSW4 Transmission Format Switch. Sets the data format and 
stop bits for the HOST/AUX port. (See "How To Set The 
Transmission Format Switches.”) 

® JCB Console Break Jumper Socket. When the pins of this 
socket are connected together, it allows any key on the ter- 
minal keyboard to activate the MONITOR break switch; it 
is essentially the same as pressing the MONITOR switch on 
the ICD. (The MONITOR switch is used to return control to 
the ICD monitor during emulation.) 
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A How to Set the 
Transmission Format 
Switches 


Factory Settings 


The transmission format switches are used to set the data 
format and stop bits for the TERMINAL and HOST/AUX ports. 
Both 8-bit, ON/OFF type switches can be set by inserting a 
small, pointed tool and sliding the bits to the ON or OFF posi- 
tion. 


Bit OFF 


ON 


1 

2 

3 

4 

5 

6 

7 

8 


Data bit 8 
No parity bit 
Even parity 
Stop bit 2 
Bit 8 always 0 
Multi-ICD I/O disable 
Multi-ICD I/O disable 
TBMT & TEOC 


Data bit 7 
Enable parity bit 
Odd parity 
Stop bit 1 
Bit 8 always 1 
Multi-ICD I/O enable 
Multi-ICD I/O enable 
TBMT only 



Factory settings of the transmission format switches for the 
TERMINAL and HOST/AUX ports are shown below. 

TERMINAL Port HOST/AUX Port 

8 data bits 8 data bits 

2 stop bits 2 stop bits 

no parity bit no parity bit 
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A Multiple ICDs 


NOTE 1: When bit 8 is set to OFF, the ICD transmits on a single 
buffer basis for monitoring the BUSY state. When this bit is set 
to ON, the ICD transmits on a double buffer basis without 
monitoring the BUSY state. 

NOTE 2: Facts about TBMT and TEOC signals: 

TBMT— Transmitted Buffer Empty. The transmitted buffer emp- 
ty flag goes to a logic "1” when the data bits holding register 
may be loaded with another character. 

TEOC— Transmitted End of Character. This line goes to a logic 
“1" each time a full character is transmitted. It remains at this 
level until the start of transmission of the next character. 

Signals for multiple ICDs can I/O through the HOST/AUX port 
by setting bits 6 and 7. When this feature is enabled, the Exter- 
nal Break, Emulation Qualify, and Event Trigger signals can be 
monitored by more than one ICD. (I/O level is EIA.) 

To activate this feature, set the following bits: 

DSW3 bit 6 = ON DSW4 bits 6 & 7 = ON 

This feature affects the following pins of the HOST/AUX port: 


Pin No. Signal Name I/O 


11 External Break IN 

18 Emulation Qualify OUT 

2S Event Trigger OUT 
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RS-232 Interface 


The RS-232 interface is the normal configuration for the ICD. 
The diagram below shows how the pins on the JA and JB sock- 
ets are arranged for the RS-232 setting. The two tables show 
the status of the signals for both the TERMINAL and 
HOST/AUX ports. 

RS-232 Pin Configuration 
(Standard connection is shown) 


24 23 22 21 20 19 18 17 16 15 14 13 



JA/JB SOCKETS JA/JB 

POWER SUPPLY 


RS-232 Interface I/O Signals— TERMINAL Port 


PIN 

No. 

SIGNAL 

NAME 

DESCRIPTION 

IN/OUT 

JANo. 

1 

FG 

Frame Ground 



2 

SD 

Send Data 

IN 

SN 751 88N 

3 

RD 

Receive Data 

OUT 


4 

RTS 

Request To Send *2 

IN 


5 

as 

Clear To Send *2 

OUT 


6 

DSR 

Data Set Ready 

OUT 


20 

DTR 

Data Terminal Ready 

IN 

J 6, J 20 *3 

7 

SG 

Signal Ground 
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RS-232 Interface I/O Signals— HOST/ AUX Port 


PIN 

No. 

SIGNAL 

NAME 

DESCRIPTION 

IN/OUT 

JB No. 

1 

FG 

Frame Ground 



2 

SD 

Send Data 

OUT (IN) ’1 

SN 751 88N 

3 

RD 

Receive Data 

IN (OUT) 


4 

RTS 

Request To Send *2 

OUT (IN) 


5 

as 

Clear To Send *2 

IN (OUT) 


6 

DSR 

Data Set Ready 

IN (OUT) 


20 

DTR 

Data Terminal Ready 

OUT (IN) 

J 6, J 20 *3 

7 

SG 

Signal Ground 




NOTE 1: Values in ( ) enabled when the DCE/DTE select 
switch is set to DOE. 


NOTE 2: CTS and RTS signals are looped back (null modem) 
within the ICD and pulled up to + 5 V. 


NOTE 3: Connecting pins 15 and 16 (JA and JB socket) together 
causes the DTR and DSR signals to be looped back (null mod- 
em) within the ICD. Connecting pins 10 and 15 QA and JB sock- 
et) causes the DTR signal to be used as the BUSY signal to the 
terminal. Connecting JA6/JB6 causes the DSR signal to be 
used as the BUSY signal to the terminal. 
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Current loop Interface The current loop interface is an optional configuration that is 

enabled when the JA and JB sockets are modified. The dia- 
gram below shows how the pins on the JA and JB sockets are 
arranged for the current loop setting. The table shows the 
status of the signals for both the TERMINAL and HOST/AUX 
ports. 

Current Loop Interface 
(Modified connection is shown) 


24 23 22 21 20 19 18 17 16 15 14 13 



123456789 10 11 12 543 


JA/JB SOCKETS JA/JB POWER SUPPLY 

A Using the Current loop a) Connect pins 4 and 21 QA18/JB18) together with a 220-ohm, 
Interface 1/4-watt resistor, or adjust the resistance to the associated 
circuit. 

b) Connect pins 2 and 23 (JA16/JB16) together with a 47-ohm, 

1 /4-watt resistor. 

c) Connect the other pins as shown in the Current Loop Inter- 
face diagram. 

d) Set the DCE/DTE select switch on the ICD to DCE. 

e) Adjust the baud rates for the TERMINAL and HOST/AUX 
ports to a maximum of 600 bps. 

NOTE: Do not change the jumpers on the line driver power 

supply (JA3/JB3, JAS/JB5). 
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TTL Interface 


Current Loop Interface I/O Signals— 
TERMINAL & HOST/AUX Ports 


PIN 

No. 

SIGNAL 

NAME 

DESCRIPTION 

IN/OUT 

JA/JB No. 

24 

LOUT+ 

Current loop OUT(+) 

IN 

J 24 

25 

LOUT- 

Current loop OUT(-) *1 

IN 

J 25 

17 

LIN + 

Current loop IN(+) *2 

OUT 

J 17 

18 

LIN- 

Current Loop IN (-) 

OUT 

J 18 220 0 

15 

RSTP+ 

Reader Step (+) 

OUT 

J 15 

16 

RSTP- 

Reader Step (-) 

OUT 

J 16 47 0 


NOTE 1: Pin 25 is the current source pin for current loop input 
signals pulled down to - 12 V. 

NOTE 2: Pin 17 is the current source pin for current loop input 
signals pulled up to + 12V. 

The TTL interface is an optional configuration that is enabled 
when the JA and JB sockets are modified. The diagram below 
shows how the pins on the JA and JB sockets are arranged for 
the current loop setting. The table shows the status of the sig- 
nals for both the TERMINAL and HOST/AUX ports. 

TTL Interface 

(Modified connection is shown) 


24 23 22 21 20 19 18 17 16 15 14 13 



O o O 


O 6 O 


3 4 5 


JA/JB SOCKETS 


JA/JB POWER 
SUPPLY 
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A Using the TTL Interface a) Remove the jumpers from JA3/JB3 and JA5/JB5 of the line 

driver power supply, and insert a single jumper into 
JA4/JB4. 

b) Connect the pins as shown in the TTL Interface diagram. 


TTL Interface I/O Signals— TERMINAL Port 


PIN 

No. 

SIGNAL 

NAME 

DESCRIPTION 

IN/OUT 

JANo. 

1 

FG 

Frame Ground 



2 

SD 

Send Data 

IN 

SN 7438 

3 

RD 

Receive Data 

OUT 


19 

BUSY 

BUSY Input 

IN 

J 19 

13 

BUSYOUT 

BUSY Output 

OUT 

J 13, J 6 *2 

16 

RSTP 

Reader Step 

OUT 

J 16 

7 

SG 

Signal Ground 




TTL Interface I/O Signals— HOST/AUX Port 


PIN 

No. 

SIGNAL 

NAME 

DESCRIPTION 

IN/OUT 

JA/JBNo. 

1 

FG 

Frame Ground 



2 

SD 

Send Data 

OUT [IN) *1 

SN 7438 

3 

RD 

Receive Data 

IN (OUT) 


19 

BUSY 

BUSY Input 

IN 

J 19 

13 

BUSYOUT 

BUSY Output 

OUT 

J 13, J 6 *2 

16 

RSTP 

Reader Step 

OUT 

J 16 

7 

SG 

Signal Ground 




NOTE 1: Values in ( ) enabled when the DCE/DTE select 
switch is set to DOE. 

NOTE 2: Connecting pins 8 and 9 (JA and JB socket) causes the 
DTR signal to be used as the BUSY signal to the terminal. 
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XON and XOFF Protocol 

XON/OFF allows terminals or host computer systems to re- 
ceive data from the ICD even if the baud rates between these 
devices are different. 


The XON/XOFF protocol works in the following manner: 


1. The host computer or terminal sends XOFF to the ICD 
before the reception buffer overruns. 


2. When the reception buffer is ready, the host computer or 
terminal sends XON to the ICD and resumes reception. 


The control codes for XON/OFF signals are: 


XON — DC3 (CTR-S; 13H) 

XOFF-DC1 (CTR-Q; 11H) 

BUSY and DTR 
Input Signals 

The BUSY signal sent from a low-speed terminal can be used 
to stop the ICD from transmitting data. Normally, the terminal 
sets the BUSY signal to low, from the leading edge of the RD 
signal starting bit, to the completion of data processing. The 

ICD suspends data transmission to the terminal as long as the 
BUSY signal is low. 
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BUSYOUT and DSR When a host computer sends data at a higher speed than the 
Output Signals ICD's internal monitor processor can accept, the BUSYOUT 
signal of the ICD must be monitored. The ICD sets the BUSY- 
OUT signal to low until the ICD monitor reads the SD signal 
from the host computer, 



RSTP Output Signal The ICD can transmit the RSTP signal to terminals that require 

a step signal for each data transmission. The ICD sets RSTP to 
low when it requests data to be read, and then returns RSTP to 
high when it detects the start bit signal from the terminal. 
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Real-time Trace Module 

Description The Real-time Trace module (S-795) allows you to record a 
portion of the program memory area and store the data in the 
real-time trace buffer. By using the HISTORY command, dif- 
ferent sections in the program can be traced, stored, and then 
dumped and displayed. 

The HISTORY command is used to control the functions of the 
real-time trace module, so there are no user-serviceable con- 
trols or components. (For a complete description of how the 
real-time trace feature works, see the HISTORY command in 
the Master Command Guide.) 
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CPU Control Module 
Description 


The CPU Control module (S-793) contains the connectors, 
circuitry, and Z80 microprocessor, which allow the ICD to 
emulate the target system’s processor. 

The only user-serviceable components on this module are the 
H, CX, and L jumpers, which allow you to set the ICD's internal 
clock speed to either 2 MHz or 4 MHz. The remaining com- 
ponents are all externally accessible. These include the CPU 
probe connectors (which connect the ICD to the target system), 
the Data Bus Emulation connector, the External Break connec- 
tor, the Event Trigger connector, and the Emulation Select 
switch, 
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Internal and External Clock 


A How to Change the 
Internal Clock 


External Clock 



Selecting the INT setting on the INT/EXT switch enables the 
ICD's internal clock. The internal clock normally runs at a 
speed of 4 MHz with a 50% duty cycle, but can be changed to 
2 MHz by modifying the jumpers on the CPU Control module. 
The clock jumper is identified by CX, and the H and L jumpers 
specify the high (H = 4 MHz) or low (L = 2 MHz) clock speed. 

To change the clock speed to 2 MHz, remove the jumper from 
the H pin and connect the L and CX pins together. 

4 MHz 2 MHz 

O O 

H CX L H CX L 

FACTORY SETTING 

Selecting the EXT setting on the INT/EXT switch enables the 
ICD to use an external clock of up to 6 MHz. The external clock 
setting allows the peripheral LSI of the target system and the 
emulation CPU to be synchronized for simultaneous operation. 
NOTE: To ensure accurate operation of the emulation CPU, a 
50% duty cycle is required for high-speed clocks greater than 
2.5 MHz. 
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ICD/Target System Z80 Pin Functions & Pin Assignments 

Interface 


ICD-278 for Z80 
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CPU Timing 


Instruction Opcode 
Fetch Cycle 


Memory Read or 
Write Cycle 


Input or Output Cycles 


Interrupt Request/ 
Acknowledge Cycle 


RD | 

WAIT “ 
Ml | 

DO • D7 — 
RFSH — 



AO • At 5 . 
MREQ 
RD 
WR 

DATA BUS [D0-D7] 
WAFT 





Tw’ T, T, 


DATA BUS 

wait :: » nr : i 


'Inserted by Z80 CPU 


Lost M Cycle . M) 

ot Instruction 

'l I '2 I V I V I T 3 





::::::: 


X 

■1 

3C 









' — 

J 








ixt:: 
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Bus Request/ 
Acknowledge Cycle 








Inst T Stati 

T x 

T x 

’x 

Tl 

“ 

\ — 

1 ' — 

* 

' — 

' — 

\ 


BUSRQ 


Sompl©^^ 



— * 



BUSAK 




A 


r 









| 








^ 

WR.Km — 







> 

BF5H 









MACHINE CYCLES 


MACHINE CYCLE 

CONTROL 

D0-D7 






MREQ 

IORQ 

RD 

WR 

Ml 

Instruction OP code 

0 

1 

0 

1 

0 

IN 

Memory Read 

0 

1 

0 

1 

1 

IN 

Memory Write 

0 

1 

1 

0 

1 

OUT 

Input 

1 

0 

0 

1 

1 

IN 

Output 

1 

0 

1 

0 

1 

OUT 

Interrupt Acknowledge 

1 

0 

1 

1 

0 

IN 

Bus Acknowledge 

TS 

TS 

TS 

TS 

1 

TS 

Reset 

1 

1 

1 

1 

1 

TS 

ICD Program Memory Read * 1 

I' 2 

1 

O' 3 

1 

X 

OUT' 3 

ICD Program Memory Write' 1 

1 

1 

1 

1 

t 

OUT 

1 0 (In-circuit Mode 0) 

r 2 

1 

1 

1 


TS 


Signal level: 0=L, 1 = H, TS=tristate, X= undefined (depends on CPU machine 
cycle) 

*1. Cycles do not access target system during memory mapping 
or in an emulation break. The ICD program memory read 
cycle can be either a Memory Read (where Ml = l) or an 
Instruction Opcode Fetch (where M1=0). 

*2. The MREQ signal (synchronized with Z80 RFSH signal) out- 
puts continuously. 

*3. RD signal suppressed when the Emulation Select switch's 
bit 2 = OFF and bit 3 = ON. 

*4. D0-D7 become tristate when the Emulation Select switch's 
bit l = OFF. 
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RESET Signal The RESET signal is used to reset the ICD monitor. The signal 
is sent by pushing the Reset switch on the Indicator/Control 
panel. This action resets the ICD monitor, but does not reset 
the target system; typically, the target system will have a man- 
ual reset switch that resets the entire system. 

Resetting the target system also causes a hardware reset of the 
ICD’s CPU registers. However, if an emulation break is in prog- 
ress, resetting the target system will not have any effect on the 
ICD’s CPU registers. The CPU registers must be reset by 
entering the REGISTER RESET command. 



IN-CIRCUIT MODE 0,1,2 



1 0 

1 1 

12 1 

MONITOR 

EMULATION 

MONITOR 

EMULATION 

MONITOR 

EMULATION | 

ICD RESET SW 

O 

X 

O 

X 

O 

nn 

RESET 

X 

X 



O 

A* 



O: Valid A: Conditional valid x: Invalid 


’ Does not reset hardware in CPU. 
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SYSTEM 

CONTROL 


CPU 

CONTROL 


CPU 

BUS 

CONTROL 


INTERRUPT Signal 


Pin Functions 


PIN ASSIGNMENTS 




Ml 

A o 

MREQ 

A 1 

IORQ 

a 3 

RD 

a 4 

WR 

As 


a 6 

RFSH 

A? 


a 8 

HALT 

Ag 


A 10 

WAIT 

All 

Z80CPU 

*12 

INT 

a 13 

NMI 

a 14 


a 15 

RESET 



°0 

BUSREQ 

°1 

BUSACK 

d 2 


d 3 

CLK 

D 4 

+ 5V 

°5 

GND 

d 6 


d 7 


ADDRESS 

BUS 


DATA 

BUS 


A 11 

2 

1 

40 

C 

A 12 

2 

2 

39 

C 

A 13 

) 

3 

38 

c 

A 14 

.1 

4 

37 

c 

A 15 

1 

5 

36 

c 

CLK 

2 

6 

35 

c 

°4 

2 

7 

34 

c 

o 3 

:j 

8 

33 

c 


:j 

9 

32 

c 

d 0 

+ 5V 

:j 

10 

11 

Z80CPU ^ 

E 

c 

d 2 

2 

12 

29 

E 

D? 

2 

13 

28 

C 

DO 

2 

14 

27 

c 

D 1 

2 

15 

26 

c 

INT 

2 

16 

25 

E 

NMI 

2 

17 

24 

c 

HALT 

2 

18 

23 

c 

MREQ 


19 

22 

c 

IORQ 


20 

21 

L 


A io 

a 9 

a 8 

a 7 

A 0 

A 5 

a 4 

a 3 

a 2 

A 1 

A 0 

GND 

RFSH 

Ml 

RESET 

BUSR EQ 

WAIT 

BUSACK 

WR 

RD 


The INTERRUPT (INT) signal returns control to the ICD mon- 
itor during emulation, and is activated by pressing the Monitor 
switch on the ICD's Indicator/Control panel. A NON-MASK- 
ABLE INTERRUPT (NMI) signal is also sent to the ICD's CPU 
when the Monitor switch is used. This NMI signal is assigned 
a higher priority than the target system’s NMI. 

The NMI signal is masked when the ICD is in an emulation 
break. However, the NMI signal from the target system is latch- 
ed by an edge-trigger circuit, so that when an NMI occurs 
during the break, an interrupt sequence is generated at the 
transition from the ICD monitor run to the target system run. 
The INT signal is also masked during an emulation break. 
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MONITOR 



ICD TARGET SYSTEM 


IN-CIRCUIT MODE 0,1,2 



1 0 

1 1 

12 1 

MONITOR 

EMULATION 

MONITOR 

EMULATION 

MONITOR 

EMULATION 

ICD MONITOR SW 

X 

O 

X 

O 

X 

O 

NMI 

X 

X 

A* 2 

O*’ 

A' 2 

O 

INT 

X 

X 

X 

O*' 

X 



O: Valid A : Conditional valid x: Invalid 

* 1 Enable/disable can be set with a PIN command, 

*2 NML Is sensed at the edge level, and if it occurs on ICD monitor run, an NMI 
sequence will occur at the transition from the ICD monitor run to target 
system run. 
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BUS Control The ICD accepts the BUSREQ signal if the in-circuit mode is II 
or 12, and is enabled and disabled by the PIN command. This 
permits direct memory access (DMA) during an ICD or target 
system emulation break. 

The WAIT signal is active when the target memory or I/O is 
accessed. This action allows the target system to operate at 
higher speeds and permits emulation when the system's ac- 
cess time is short. 


Z80 


PROB1 


BUSREQ 


E< 

< i 


BUSACK 


TIMING 

LOGIC 


I 

lo^ OFF 

OON 

I ENSEL 
J [Bit 4) 


I/O 

MEMORY 

CONTROL 


ICD 


TARGET SYSTEM 


IN-CIRCUIT MODE 0,1 


BUSAK 

WAIT 


.2 


MONITOR 

x 

X 


10 

EMULATION 


MONITOR 


x 


o* 


X A 


M 

EMULATION 

Q‘ 

O* 


MONITOR 

O 

A 


12 

EMULATION 

O 

O 


O: Valid A: Conditional valid x: Invalid 

‘WAIT signal is valid If the ICD monitor accesses the target system. 
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A Setting Different 
Wait States 


REFRESH Signal 


The ICD can insert 1, 2, or 3 wait states into a machine cycle by 
setting the jumpers on the CPU Module. The normal setting is 
2 wait states per machine cycle. To change to 1 or 3 wait states, 
carry out the procedure below. 

For 3 wait states— remove the jumper from WT and 2C pins. 


For 1 wait state— connect the jumper to WT and 1C pins as 
shown below. 

2 WAIT STATES 

1 WAIT STATE 

3 WAIT STATES 

o 

1C WT 2C 

o 

1C WT 2C 

O O O 

1C WT 2C 

FACTORY SETTING 




The RFSH signal outputs to the target system during all (0, 1, or 
2) in-circuit modes. The memory request (MREQ) signal for 
refresh is then synchronized with the RFSH signal (indepen- 
dent of the in-circuit mode). This procedure allows the refresh 
timing of the target system D-RAM to be synchronized with the 
CPU. 



ICD 


TARGET SYSTEM 
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ICD-278 Signal Timing 
Diagram 





Z-SO 

Z-SOA 

Z-80B 

ICD278 











for Z80 


Signal Symbol 

Parameter 

Min. 

Max. 

Min. 

Max. 

Min. 

Max. 

Min. 

Max. 

Unit 



Check Period 

4 

30 

25 


165 


165 

fxsec 


f w(<*H) 

Check Pulse Width, Clock High 

180 


110 


65 


65 


ns 

<4 

f w((4L) 

Clock Pulse Width, Clock Low 

180 2000 

1102000 

652000 

652000 

ns 


*r,f 

Clock Rise and Fall Time 


30 


30 


20 


20 

ns 


f d (AD) 

Address Output Delay 


145 


110 


90 


105 

ns 


f F (AD) 

Delay to Float 


110 


90 


80 


120 

ns 

Ao-13 

^cm 

Address Stable Prior to MREQ (Memory Cycle) 

125 


65 


35 


35 


ns 


tael 

Address Stable Prior to IORQ (IO Cycle) 

320 


180 


100 


110 


ns 


♦ca 

Address Stable from RD, WR, IORQ or MREQ 

160 


80 


35 


35 


ns 


f D(D) 

Data Output Delay 


230 


150 


130 


145 

ns 


+ F (D) 

Delay Float During Write Cycle 


90 


90 


80 


120 

ns 


f Sd (D) 

Data Setup Time to Rising Edge of Clock During M Cycle 

50 


35 


30 


45 


ns 

D„ 

f Sd (D) 

Data Setup Time to Falling Edge of Clock During M2 to M5 

60 


50 


40 


55 


ns 


^dcm 

Data Stable Prior to WR (Memory Cycle) 

190 


80 


25 


25 


ns 


f dcl 

Data Stable Prior to WIT (I/O Cycle) 

20 


10 


55 


55 


ns 


^cdi 

Data Stable From WR 

120 


60 


30 


30 


ns 


♦h 

Any Hold Time for Setup Time 

0 



0 


0 


0 

ns 


tou* (MR) MREQ Delay From Falling Edge of Clock, MREQ Low 


100 


85 


70 


85 

ns 


toFId (MR) MREQ Delay From Rising Edge of Clock, MREQ High 


100 


85 


70 


85 

ns 

MREQ *DHd (MR) MREQ Delay From Falling Edge of Clock, MRE& High 


100 


85 


70 


85 

ns 


f w(MRL) 

Pulse Width, MREQ Low 

360 


220 


135 


135 


ns 


f w(MRH) 

Pulse Width, MREQ High 

170 


110 


65 


65 


ns 


f DW(IR) 

IORQ Delay From Rising Edge of Clock, I'ORQ tow 


90 


75 


65 


80 

ns 


'DLs* (IR) 

IORQ Delay From Falling Edge of Clock. IORQ Low 


110 


85 


70 


85 

ns 

IUR5 

f DH(4(IR) 

IORQ Delay From Rising Edge of Clock, IORQ High 


100 


85 


70 


85 

ns 


♦DHiJ (IR) 

IORQ Delay From Falling Edge of Clock, IORQ High 


110 


85 


70 


85 

ns 
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ICD-278 Signal Timing 
Diagram 


Signal Symbol 

Parameter 

Z-80 

Min. Max. 

Z-SOA 

Min. Max. 

Z-SOB 

Min. Max. 

ICD278 
for ZSO 

Min. Max. 

Unit 


W(RD) 

RD Delay From Rising Edge of Clock, RD Low 


too 


85 


70 


85 

ns 


W(RD) 

RD Delay From Falling Edge of Clock, RD Low 


130 


95 


80 


95 

ns 

ED 

*DH(4 (RD) RD Delay From Rising Edge of Clock, RD High 


too 


85 


70 


85 

ns 


f DH<4 (RD) RD Delay From Falling Edge of Clock, RD High 


110 


85 


70 


85 

ns 


Hxd (WR) WR" Delay From Rising Edge of Clock, WR Low 


80 


65 


60 


75 

ns 


'DLsT (WR) WR" Delay From Falling Edge of Clock, WR Low 


90 


80 


70 


85 

ns 

WR" 

tDHd (WR) WffDelay From Falling Edge of Clock, WfifHIgh 


100 


80 


70 


85 

ns 


*w(WRL) 

Pulse Width. WR Low 

360 


220 


135 


135 


ns 


f DL (Ml) 

MTDelay From Rising Edge of Clock, MT Low 


130 


100 


80 


95 


tvPT 

*DH (Ml) 

MT Delay From Rising Edge of Clock, MTHIgh 


130 


100 


80 


95 



f DL(RF) 

RFSH Delay From Rising Edge of Clock, RFSH Low 


180 


130 


110 


125 


EF5R 

tDH(RF) 

RFSH Delay From Rising Edge of Clock, RFSH High 


150 


120 


100 


115 

ns 

WAIT 

‘stWI) 

WAIT Setup Time to Falling Edge of Clock 

70 


70 


60 


80 

ns 


HALT 

f D(HT) 

HALT Delay Time From Falling Edge of Clock 


300 


300 


260 


275 

ns 

Tnt 

f s (IT) 

INT Setup Time to Rising Edge of Clock 

80 


80 


70 


100 


ns 

NMI 

tw (NML) 

Pulse Width, NMI Low 

80 


80 


70 


30 


ns 

BUSRQ 

ts(BQ) 

BUSRQ Setup Time to Rising Edge of Clock 

80 


50 


50 


65 


ns 


f DL (BA) 

BUSAK Delay From Rising Edge of Clock, BUSAK Low 


120 


100 


90 




BUSAK t DH (BA) 

BUSAK Delay From Falling Edge of Clock, BUSAK High 


110 


100 


90 




RESET 

(RS) 

RESET Setup Time to Rising Edge of Clock 

90 


60 


60 


75 


ns 


f F(C) 

Delay to Float (MREQ, IORQ, RD andWE) 


100 


80 


70 


120 

ns 


y 

Ml Stable Prior to IORQ (Interrupt Ack.) 

920 


565 


365 


365 


ns 
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Emulation Memory 
(Unit) Module 

Description 


The Emulation Memory (EMU) module (S-792) manages the 
ICD emulation memory and the mapping of the target system’s 
memory. The EMU module contains no user-serviceable con- 
trols or components; all functions are activated using the de- 
bugger commands. 
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ICD Emulation Memory The ICD-278 for Z80 features 64K bytes of RAM which is called 

ICD emulation memory. This memory can be used for down- 
loading object files, and altering or manipulating the target 
system's memory. 

The ICD emulation memory is composed of high-speed static 
RAM which allows the support of multi-speed target systems. 
When viewed from the target system, ICD emulation memory is 
different from a normal memory area in that it is contained within 
the Z80 processor. And, because of the special characteristics of 
the ICD emulation memory, DMA transfer between the target 
system and the ICD emulation memory is not possible; however, 
DMA transfer between the address spaces within the target 
system is permitted. 
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Target System Memory The memory contained in the target system is called target mem- 
ory or user memory. The ICD can address up to 64K bytes of 
target memory. 

The access time required to write to the target memory from the 
ICD is identical to that of the processor; however, the access time 
needed to read from the target system memory is slightly shorter 
than that available with the processor. Therefore, certain access 
time conditions must be satisfied for accurate reading. These 
conditions are shown below: 



— - — - . 

OP code Fetch 

Memory I/O 
Read 

t D (AD) 

Address Output Delay 

Max. 

Max. 90 ns 

t S * CD] 

Data Setup Time to Rising Edge 
of clock during Ml Cycle 

min. 30 ns 

min. 40 ns 

tH 

Any Hold Time for Setup time 

in. 0 ns 

min. 0 ns 
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Mapping You can use all or part of the ICD's RAM in place of target 
memory by creating a memory map. The emulation memory 
or target system memory can be mapped in increments of 
IK bytes using the MAP command. (For an explanation and 
examples of how this works, see the MAP command in Sec- 
tion 2.) 



ICD PROGRAM EMULATION CPU USER MEMORY 

MEMORY MEMORY MAP 
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Power Supply 
Specifications 


Line voltage: 100 to 120 volts AC 
200 to 240 volts AC 
Frequency: 50 or 60 Hz 
Power: 40 watts 

Output voltage: + 5 volts DC 
+ 12 volts DC 
- 12 volts DC 

The Power Supply provides 5 volts to the control modules and 24 
volts to the external cooling fan. The voltage to the control mod- 
ules is filtered to reduce noise from the power supply line. 
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How To Disassemble 
Your ICD 

Introduction The ICD must be partially or fully disassembled in order to 
modify the components and controls, or to change certain set- 
tings on the control modules. Here you will find the procedure 
for disassembling the ICD and removing (and installing) the five 
control modules, 

Important Notice Before you begin any disassembly of your ICD, you should be 
To Users! aware of certain guidelines which must be followed in order to 

preserve the Warranty Policy on this equipment. 

1. All adjustments and modifications to the ICD are limited to 
the SIO and CPU control modules. The adjustments and 
modifications which are authorized by ZAX are clearly 
identified (A) in each of these chapters. Any other altera- 
tions or adjustments on the SIO and CPU control modules 
void the Warranty Policy. 

2. Do not adjust, modify, and/or in any way alter the controls 
or components on any of the three remaining modules 
(Indicator/Control, Real-time Trace, or Emulation Memory 
Unit) or the power supply. 

3. Follow the disassembly procedure described here. Damage 
may result if the ICD is disassembled, or the modules re- 
moved, in a manner other than that described in this chap- 
ter. 
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The Basic Parts 
Of Your ICD 


The construction of all ZAX ICD-series emulators is very sim- 
ilar. The basic ICD unit includes the mainframe, the five control 
modules, the power supply, the Mother Bus cable, and the out- 
side casing. The mainframe is a metal chassis that houses the 
control modules and the power supply. The five control modules 
are circuit boards (sometimes called "cards”) which do the 
actual work of emulating the target system. The power supply 
provides voltage for the modules. The Mother Bus cable permits 
the modules to communicate with each other. The ICD case 
consists of a top cover, bottom cover, and two side covers. 

® Main Frame 
© Side Cover 
® Control Modules 
© Top Cover 
© Power Supply 
© Bottom Cover 
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Procedure For 
Disassembling The ICD 

WARNING HAZARDOUS VOLTAGE IS PRESENT WITHIN THE ICD-278. 

DISCONNECT THE AC POWER PLUG BEFORE BEGINNING 
ANY INTERNAL WORK ON THE ICD-278. 

1. Remove the two side covers and the top cover. 

a) Remove the four raised screws that connect the top cover 
to the mainframe. 

b) Remove the eight countersunk screws on the side covers. 

c) Detach the side covers and the top cover. 
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How The Modules Each module is linked by the 60-pin Mother Bus cable. Power is 
Are Connected supplied to each module by a 5-pin, plug-type power connector 
cable (except for the S-730 module which receives its power from 
the Mother Bus cable). The power and Mother Bus cables must 
be detached before removing any of the control modules. 

IMPORTANT: Note the position of the power connectors before 
removing them. Both the socket and plug have a black label on 
one side which marks the polarity of the connectors. 



ICD-278 for Z80 
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Procedure For 
Removing The Modules 


1. Free the power cable by disconnecting the five-pin socket 
(CN4) from the module. 

2. Detach the Mother Bus cable from the modules (location 
CN1). 

3. Remove the screws which hold the modules to the main- 
frame. 

a) The top and bottom (S-730 and S-792) modules are 
mounted directly to the mainframe with four and six 
screws, respectively. Remove these screws to detach 
the modules. 

b) The three remaining modules (S-791, S-795, and S-793) 
are connected to brackets which are attached to the 
ICD's mainframe at one end and slide into holders at 
the other end. To detach these modules, remove the 
screws and then carefully slide the modules away from 
the mainframe. 
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Installing The Modules 


Tb install the modules, reverse the "removing the modules” pro- 
cedure. 

CAUTION: DO NOT REVERSE POWER CONNECTOR POSI- 
TION DURING INSTALLATION. CONNECTOR MISPLACE- 
MENT WILL CAUSE DAMAGE TO THE ICD-278. 

NOTE: When replacing the side panels, loosely position all the 
screws in place to allow the panels to align properly before 
tightening the screws. 


3-44 ZAX Corporation 


ICD-278 for Z80 


Section 4 


COMMUNICATION PROTOCOL 


Contents 


SECTION 4 - COMMUNICATION PROTOCOL 

4-1 Introduction 

4-2 REMOTE Mode 

4-3 Idle Program 

4-4 Command Request Program 

4-6 Function Analysis Program 

4-7 Text Display Program 

4-9 Object File Load/Verify Program 

4-13 Object File Save Program 

4-16 Illegal/“Z” Command Program 

4-18 Quit Program 

4-19 Console Key Check Program 

4-20 Symbol/Numeral Conversion Program 

4-21 Symbolic Text Display Program 

4-23 LOCAL Mode 

4-24 Idle Program 

4-26 Console Command Request Program 

4-27 Remote Command Request Program 

4-29 Function Analysis Program 

4-30 Object File Load/Verify Program 

4-34 Object File Save Program 

4-38 Illegal/ "Z” Command Program 

4-40 Quit Program 

4-41 Symbol/Numeral Conversion Program 

4-43 Numeral Conversion Program 

4-45 Symbolic Text Display Program 

4-47 Command & Text Execution Program 

4-49 Console Command Input/Output Program 

4-50 Console Character Read Program 

4-52 Console Text Read Program 

4-54 Console Character Write Program 

4-55 Console Text Write Program 

4-57 Number Conversion Codes 
4-58 Symbol Conversion Codes 

4-63 Intel Hex Object Format 

4-68 S Format Object File 


ICD-278 for Z80 


ZAX Corporation 



Section 4 


COMMUNICATION PROTOCOL 


Introduction 


Your ICD can operate in one of two different system configura- 
tions with a host computer. In one configuration, a host com- 
puter is used to directly control the ICD via ZICE software; this 
is called the REMOTE mode. In the other configuration, the 
ICD is under the direct control of a console terminal and uses 
a computer as either a data storage facility, or as a conduit to 
the ZICE commands (i.e. , help files, "Z” commands, etc.); this 
is called the LOCAL mode. (The HOST command activates the 
LOCAL "host computer assisted” mode.) 

In either configuration, when the ICD is used with a host com- 
puter supported by ZICE software, certain communication 
rules are observed to ensure an orderly information exchange 
between the ICD and the host computer system. This is called 
communication protocol. 

In this section you'll be shown (using diagrams) the proper 
communications protocol (for both the REMOTE and LOCAL 
modes. The diagrams show the contents of the communication 
messages from both the ICD and host computer, and the se- 
quence in which they are executed. You can use the commu- 
nication programs to write your own support software for use 
with your particular host computer system. 

NOTE: Although this manual is specifically designed for the 
ICD-278's Z80 CPU, this section can be used with ALLZAXICD- 
series emulators that feature "backslash" (\) protocol format. 
This format is structured as: \code(text)<CR>. A Number 
and Symbol Conversion Code chart which shows the correct 
numbers and symbols to use with your particular emulator is 
shown at the end of this section. 
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REMOTE MODE: 
PROGRAM: 


PROGRAM DESCRIPTION: 

ACTION: 


HOST COMPUTER CONTROL OF THE iCD 

IDLE 



This program acts as the main intermediary program (transfer- 
ring instructions and text only) between the ICD and the sub- 
programs (Command Request, Text Display, and Function 
Analysis). 

1. The host computer waits for an input from the ICD. (The host 
system must have an input buffer to hold the input code from 
the ICD.) 

2. The host computer receives one line of data and places it in 
the input buffer. 


3. The host computer then executes one of the following pro- 
grams depending on the code it receives: 


Code Received Program Executed 


\F0<CR> 
\80{text)<CR> 
any other 


COMMAND REQUEST 
TEXT DISPLAY 
FUNCTION ANALYSIS 
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ORIGIN 

ACTION: 

Sends a command from the host computer in response to a com- 
mand request from the ICD. 

ICD 

\F0(text)<CR> 

COMMAND REQUEST RECORD. This record is a command 
request sent from the ICD to the host computer. This record also 
contains the ASCII text to be displayed on the host computer’s 
terminal screen, but does not include <ACK>, <NAK>, 
<CR>, or <SOFI>. The host computer then displays the 
<text> on the console screen. 

HOST 

\F9( command) 
<CR> 

COMMAND RECORD. ASCII text is sent as a command from the 
host computer to the ICD. This record cannot contain any control 
code and must end with <CR>. When the record is entered 
through the host computer’s console, the system accepts one 
line of data echoing it back to the console screen. 



NOTE: The cursor stays on the same line after the echo. To 
move the cursor to the next line, the ICD sends a code in the 
text display sequence. 


PROGRAM 

DESCRIPTION: 

COMMAND REQUEST 


ACTION: 

1. The ICD requests a command by sending \F0{text) <CR> 
to the host computer. 



2. Upon receiving \ F0{ text) < CR> from the ICD, the host com- 
puter waits for an input after displaying the text record on the 
console screen. 



3. If a command record is entered from the host computer, the 
system sends \F9{text) <CR> to the ICD and then returns 
to the IDLE program. 
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PROGRAM: FUNCTION ANALYSIS 



REMOTE MODE 
PROGRAM 
FLOWCHART 


r 

i 

1 

1 


1 


1 

OBJECT FILE 
LOAD/VERIFY 
PROGRAM 


OBJECT FILE 
SAVE 

PROGRAM 


ILLEGAL rZ” 
COMMAND 
PROGRAM 


QUIT 

PROGRAM 


CONSOLE KEY 
CHECK 
PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOLIC 
TEXT DISPLAY 
PROGRAM 


ACTION: 1. The host computer places one line of data (received from the 

ICD) into the input buffer and analyzes the data. 

2. The host computer then executes one of the following pro- 
grams based upon the contents of the input buffer: 


Input Buffer Contents 

\ 00 ( filename } <CR> 
or \ 02 {filename ) <CR> 

\ 01 (filename) <CR> 
or \ 03 (filename ) <CR> 

\ 10 (filename) <CR> 
or \ 12{filename) <CR> 

\ 43 ( parameter ) < CR > 

\44<CR> 

\ 2X{ symbol )<CR> 

\ 88 

or \ 8A<CR> 

\ 3X{ parameter ) ( text ) < CR > 


Program Executed 
FILE LOAD 

FILE VERIFY 

FILE SAVE 

"Z” COMMAND 
QUIT 

SYMBOL CONVERSION 

Checks the console 
input in the host 
computer. 

SYMBOLIC TEXT DISPLAY 
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PROGRAM: 


TEXT DISPLAY 


IDLE 

PROGRAM 


COMMAND 


FUNCTION 


TEXT 

REQUEST 


ANALYSIS 


DISPLAY 

PROGRAM 


PROGRAM 


PROGRAM 


REMOTE MODE 
PROGRAM 
FLOWCHART 


OBJECT FILE 
LOAD/VERIFY 
PROGRAM 


OBJECT FILE 
SAVE 

PROGRAM 


ILLEGAL rZ” 
COMMAND 
PROGRAM 


OUIT 

PROGRAM 


CONSOLE KEY] 
CHECK 
PROGRAM 


SYMBOU 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOLIC 
TEXT DISPLAY 
PROGRAM 


ICD 

Host Computer System 

\80(text) <CR> 




or \82(text)<CR> 

"l/ 






(text display record to console) 

1 

1 


\ 4 . 



or \F7<CR> 
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ORIGIN ACTION: Tfext sent from the ICD is displayed on the console screen of the 

host computer. 

ICD \80 < CR > TEXT RECORD. This record is ASCII text sent to the host com- 

puter's console screen from the ICD. (NOTE: <ACK>, 

< NAK > , < ENQ >, or < SOH > cannot be contained in the text 
record.) 

The host computer displays one line of the text record up to 

< CR > , and then moves the cursor to the start of the next line. 

HOST \ F8 < CR > DISPLAY COMPLETE ACKNOWLEDGE. This code is sent to 

the ICD when the display has been completed. 

HOST \F7<CR> DISPLAY INTERRUPT CODE. This code is sent to the ICD to 

interrupt it from sending a text record during the display of a 
"scrolling" display command (e.g., DUMP, TRACE, etc.). 

PROGRAM 

DESCRIPTION: TEXT DISPLAY 

ACTION: 1. The TEXT DISPLAY program is requested when the ICD 

sends \80 { text ) < CR > to the host computer. 

2. The host computer displays the text record on the console 
screen. 

3, The host computer then checks the console input status and 
executes one of the following: 

a) If no input is given, the host computer sends \F8<CR> 
to the ICD and returns to the IDLE program. 

b) If the input code is ESC, the host computer sends 
\F7<CR> to the ICD and returns to the IDLE program, 
suspending any further text display. 

c) If the input is a code other than ESC, the host computer 
sends \F8<CR> to the ICD and returns to the IDLE 
program, 
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PROGRAM: OBJECT FILE LOAD/VERIFY 



ORIGIN ACTION: An object file is sent from the host computer in response to a 

LOAD/VERIFY request from the ICD. 

NOTE: The transmission of the object file maybe interrupted 
by a text display request ora console check sequence. 

ICD \ 00 ( filename } < CR > INTEL HEX LOAD REQUEST RECORD or S FORMAT LOAD 

or \02{ filename) <CR> REQUEST RECORD. This record is sent to the host computer 

when the ICD loads an object file. 

ICD \01 { filename )<CR> INTEL HEX VERIFY REQUEST RECORD or S FORMAT VER- 

or \ 03 ( filename } <CR> IFY REQUEST RECORD. This record is sent to the host com- 

puter when the ICD verifies an object file with the memory. 

HOST ( record ) < CR > OBJECT FILE RECORD. This Intel Hex or S format record is sent 

to the ICD from the host computer. This record may not contain 
any control code, and must end with < CR > . 

ICD \ F8 < CR > OBJECT RECORD ACKNOWLEDGE CODE. This code is sent 

by the ICD to acknowledge successful receipt of an Intel Hex 
or S format record. 
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ICD 

\F6<CR> 

OBJECT RECORD RE-TRANSMISSION REQUEST CODE. This 
code is used when the ICD requests the host computer to re- 
transmit the object record, usually due to a check sum error. 

ICD 

\F7<CR> 

OBJECT FILE TRANSMISSION INTERRUPT CODE. This code 
ends the LOAD/VERIFY sequence due to irrecoverable error. 

ICD \80{text} <CR> 
(at text display) 

TEXT RECORD. This record contains a verify error message. 

HOST 

\F8<CR> 
(at text display) 

DISPLAY COMPLETE CODE. 

HOST 

\F7<CR> 
(at text display) 

LOAD/VERIFY SEQUENCE ABORT INDICATION CODE. The 
host computer may abort the LOAD/VERIFY sequence by send- 
ing this code to the ICD. 

ICD 

\8A<CR> 
(at console key 
input check) 

CONSOLE KEY INPUT CHECK REQUEST CODE. This re- 
quest is generally used to check the status of an abort, or inter- 
rupt of the verify error messages. 

HOST 

\F8<CR> 
(at console key 
input check) 

NO-CONSOLE-INPUT CODE. 

HOST 

\F9{ any ASCII 
code)<CR> 
(at console key 
Input check) 

CONSOLE INPUT CODE 

HOST 

\F7<CR> 
(at console key 
input check) 

LOAD/VERIFY SEQUENCE ABORT INDICATION CODE. The 
host computer can abort the object LOAD/VERIFY sequence by 
sending this code to the ICD. 

HOST 

\F1<CR> 

LOAD/VERIFY END CODE. The host computer sends this code 
to the ICD (after closing the file) if the file records are exhausted. 

An object LOAD/VERIFY sequence ends this code. 

HOST 

\F7<CR> 

LOAD/VERIFY SEQUENCE ABORT INDICATION CODE. The 
host computer uses this code to inform the ICD it is aborting the 
LOAD/VERIFY sequence. 
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Host Computer System 


\0X (filename) <CR> I 


\F8<CR> 


nF 6<CR> 


\F8 <CR> 


\80 (text)<CR> 


1^8A<CR> 


\F8<CR> 


(designated file open) 
(read Intel HEX or S format record) 

i 

( file record ) < CR > 4J 


(read Intel HEX or S ( format record) 
(file record) <CR>4-* 


(file record) <CR ><--* 

(read Intel HEX or S format record) 
(file record) <CR>4-1 


(text display record) 


■ '<;F8<CR> or \F7<CR> ^ 1 


(console key in check) 

, \F8<CR> or \F7<CR> ^ j 

\ F9 ( character ) < CR > 

(designated file close) 
\F1<CR> or \F7<CR> 4 i 


(to command Input request sequence etc.) 


ICD-278 for Z80 


ZAX Corporation 4-11 



COMMUNICATION PROTOCOL 


Section 4 


PROGRAM DESCRIPTION: OBJECT FILE LOAD/VERIFY 

ACTION: 1. The ICD sends \ OX ( filename ) < CR > to the host computer 

to load or verify a user program. 

2. The host computer then opens the requested program file, 
and acts on the following: 

a) If an error occurs when opening or reading the file, the 
host computer sends \F7 < CR> to the ICD and returns 
to the IDLE program. 

b) If no error is detected, the host computer sends the Intel 
Hex or S format record to the ICD and then waits for 
\F8<CR> from the ICD. 

If the host computer receives \ F8 < CR > , it then reads the 
Intel Hex or S format record. If the code is \F7<CR>, 
the host computer sends \F8<CR> after closing the file 
and then returns to the IDLE program. 

If the code is \F6<CR>, the host computer waits for 
\F8<CR> after re-transmitting the Intel Hex or S format 
record to the ICD. 

When the text record is received from the ICD, the host 
computer displays the text record on the console screen 
and then waits for \ F8 < CR > . 

If \8A<CR> is received from the ICD, the host com- 
puter sends \F8 < CR > to the ICD if there is no input, or 
"\F9< any ASCII code>” when there is an input. 

c) If there is no record to send when \ F8< CR> is received 
from the ICD, the host computer closes the file, sends 
\ FI < CR > to the ICD, and returns to the IDLE program. 
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PROGRAM: OBJECT FILE SAVE 

REMOTE MODE 
PROGRAM 
FLOWCHART 


ORIGIN ACTION: The host computer receives an object program and creates a file 

upon receiving a save request from the ICD. 

ICD \ 10 [ filename } < CR > INTEL HEX SAVE REQUEST RECORD or 

or \ 12 { filename } < CR > S FORMAT SAVE REQUEST RECORD. This record is sent by the 

ICD to request the host computer to save a file. 

HOST \ F8 < CR > OBJECT RECORD REQUEST CODE. This code is sent to the 

(at file write) ICD from the host computer to request an Intel Hex or S format 

record. 

ICD { record ) < CR > OBJECT FILE RECORD. This Intel Hex or S format record is sent 

to the host computer. 

HOST \F6<CR> OBJECT FILE RE-TRANSMISSION REQUEST CODE. This 

code is used when the host computer requests the ICD to re- 
transmit the object file. NOTE: Most re-transmission requests 
are caused by a sum check error of an Intel Hex or S format 
record. 

ICD \ FI < CR > FILE END CODE. This code is sent to the host computer when 

the file record transmission is exhausted. 



ICD-278 for Z80 


ZAX Corporation 4-13 




COMMUNICATION PROTOCOL 


Section 4 


ICD 

\ F7 < CR > 

SAVE SEQUENCE ABORT REQUEST CODE. This code directs 
the host computer to abort the object save sequence. 

HOST 

\F8<CR> 
(at file close) 

FILE CLOSE END CODE. The host computer sends this code 
to the ICD, in response to \F1 < CR> , if the file has been closed 
successfully, then returns to the IDLE program. 

HOST 

\F7<CR> 

SAVE SEQUENCE ABORT INDICATION CODE. The host com- 
puter uses this code to inform the ICD that it is aborting the 
object save sequence. 


PROGRAM 

DESCRIPTION: 

OBJECT FILE SAVE 


ACTION: 

1. The ICD sends s1X{filenameJ <CR> to the host computer 


when saving a user program. 


2. The host computer opens the selected user file when it re- 
ceives the \ 1X{ filename }<CR> code. 

If the file does not open, the host computer sends \ F7 < CR > 
to the ICD and returns to the IDLE program. If the file opens, 
the host computer sends \F8<CR> to the ICD. 

3. The host computer waits for the Intel Hex or S format record 
from the ICD. The host computer then executes a file write 
of the record received from the ICD. If an error occurs dur- 
ing the file write operation, the host computer closes the 
user program file, sends \F7 < CR> to the ICD, and returns 
to the IDLE program. 

If an error occurs in a check sum, the host computer waits 
for a retransmission of the Intel Hex or S format record from 
the ICD after sending \F6< CR > . The host computer then 
sends \F8 < CR > to the ICD if no error occurs during the 
file write. 
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Host Computer System 


\ IX ( filename )<CR> 


(designated file make) 


\F8<CR> 


( Intel HEX record ) < CR > 
or ( S format record ) < CR > 


(write Intel HEX or S format record) 


( Intel HEX record ) < CR > | 
or ( S format record ) < CR > 

Retransmit * 

( Intel HEX record ] <CR> I 

or ( S format record ) < CR > 


\FS<CR>4-- 


\F6<CR> «~ 


(when receive record error) 

I 


(write Intel HEX or S format record) 


xFI <CR> 
or \F7<CR> 


\F8<CR> 4- 


(designated file close) 


■ \F8<CR>or \F7<CR> 
(to IDLE program ) 
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PROGRAM: 


ILLEGAL/ 1 ?” COMMAND 


REMOTE MODE 
PROGRAM 
FLOWCHART 


r 

f T 1 

I I I 




OBJECT FILE OBJECT FILE 
LOAD/VE RJFY SAVE 

PROGRAM PROGRAM 


ILLEGAL /“Z” 
COMMAND 
PROGRAM 


QUIT 

PROGRAM 


CONSOLE KEY 
CHECK 
PROGRAM | 


SYMBOL! 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOLIC 
TEXT DISPLAY 
PROGRAM 


Host Computer System 


command 
8c parameter 


|<CR> 1 ^ 


Illegal command 
"Z" command procedure 

i 

i 

\F8<CR> or \F7<CR> 4-' 
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ORIGIN ACTION: This sequence is used to process an ILLEGAL or "Z" com- 

mand, according to the parameters sent from the ICD. The 
ILLEGAL command is a command not defined in the ICD, but 
is interpreted and processed by the host computer. The host 
computer can use the ILLEGAL and "Z” commands to process 
a HELP command or the macro commands. 

ICD \43 1 parameter ) ILLEGAL/"Z" COMMAND RECORD. This record is sent to the 

<CR> host computer to process the ILLEGAL/"Z” command. 

HOST \F8<CR> ILLEGAL/ M Z" COMMAND NORMAL END CODE. This code 

is sent to the ICD when the ILLEGAL/"Z” command has been 
processed successfully. 

HOST \F7<CR> ILLEGAL/"Z” COMMAND ABNORMAL END CODE. This 

code is sent to the ICD when the ILLEGAL/"Z” command has 
not been processed successfully. 

PROGRAM 

DESCRIPTION: ILLEGAL/“Z” COMMAND 

ACTION: 1. The ICD sends \ 43 { parameter) <CR> (and the specified 

"Z" command) to the host computer. 

2. The host computer performs the specified "Z" command 
and then acts on the following: 

If an error is contained in the "Z” command specification, 
the host computer sends \F7<CR> to the ICD and then 
returns to the IDLE program. 

If no error is detected, the host computer sends \F8<CR> 
to the ICD and then returns to the IDLE program. 

NOTE; The ICD does not react differently to the \F7 < CR > than 
it does to the \F8<CR> code. It normally assumes that the host 
program has issued its own error messages if an error has 
occurred. 
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ORIGIN 

ICD 


PROGRAM: QUIT 



REMOTE MODE 
PROGRAM 
FLOWCHART 



ICD 


Host Computer System 

\44<CR> - 

► - 




I 



i 



(return to OS) 


ACTION: The host computer returns to the operating system (OS) indi- 

cated by the ICD’s code. 

\ 44 < CR > QUIT RECORD. 
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PROGRAM: CONSOLE KEY CHECK 



ICD 

Host Computer System 

^8A<CR> 

^ 1 

1 


1 

+ 


(console key check) 

«- 

\F8<CR> a } 

or ^ F<5 f character ) < CR >" 


ORIGIN ACTION: The ICD uses this sequence to check the console input to the 

host computer. (The console input could be an inquiry about 
an interruption, restart or abort trace sequence, or dump out- 
put.! 

ICD \8A<CR> CONSOLE KEY INPUT CHECK REQUEST RECORD. This 

record is sent to the host computer to request a console key 
input check. 

HOST \F8<CR> NO CONSOLE INPUT RECORD. This record is sent to the ICD 

if there is no console input. 


HOST \ F9 (any ASCII code ) 
<CR> 


The host computer sends " < any ASCII code > " if there is any 
console key input. 
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PROGRAM: SYMBOL/NUMERAL CONVERSION 


ORIGIN 


ACTION: 


ICD \2X( symbol) 
<CR> 


HOST \F9 0 (number 
(hexadecimal ASCII) ) H 
<CR> 


HOST 


\F1 <CR> 


IDLE 

PROGRAM 


REMOTE MODE 
PROGRAM 
FLOWCHART 


COMMAND 


FUNCTION 


TEXT 

REQUEST 


ANALYSIS 


DISPLAY 

PROGRAM 


PROGRAM 


PROGRAM 


OBJECT FILE 


OBJECT FILE 


ILLEGAL /“Z” 

LOAD/VERIFY 


SAVE 


COMMAND 

PROGRAM 


PROGRAM 


PROGRAM 


QUIT 

PROGRAM 


ICONSOLE KEY 
CHECK 
PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOLIC 
TEXT DISPLAY 
PROGRAM 


ICD 

Host Computer System 

\2X (symbol) <CR> Cl 

<= 

\F90 (Number) H <CR> 

■ * or\F1<CR> 


This sequence is used when the host computer requests a 
symbol or numeral conversion. 


SYMBOL/NUMERAL CONVERSION REQUEST RECORD. 
This is a record sent to the host computer requesting numeric 
conversion of a symbol. (The ICD sends (symbol ) <CR> in- 
cluding which means a symbol.) 


NUMERIC RECORD This record is sent to the ICD when the 
symbol received from the ICD has been converted to a 
numeral. (The host computer attaches 0 to the head of the con- 
verted value and “H”<CR> at the end.) 


SYMBOL/NUMERAL CONVERSION ERROR CODE. This 
code is sent by the host computer when the symbol chosen 
cannot be converted to a numeral, 
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ORIGIN 

ICD 


PROGRAM: SYMBOLIC TEXT DISPLAY 



ICD 


Host Computer System 


\3E (text) 


\3X (parameter) C 
(text)<CR> C 




<■ 


1 

(change parameter tor symbol) 
(display symbol & text to console) 

\F8<CR> or \F7<CR> 


ACTION: The parameters sent from the ICD are displayed on the con- 

sole screen after being converted to symbols. 


\ 3X{ parameter ) SYMBOL CONVERSION RECORD. This record tells the host 
< CR > computer to display the parameters after converting to sym- 

bols. 
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HOST 


HOST 


NOTE: The control codes < ACK > , < NAK >, and < ENQ > are 
not allowed in the symbolic text record. 

NOTE: The header 3X before {parameter} may contain values 
from 30 to 3F. 

\ F8<CR> DISPLAY COMPLETE CODE. This code is sent to the ICD 
when the symbol display and text in the symbolic text record 
have been completed. 

\ F7<CR> DISPLAY INTERRUPT INDICATION CODE. The host com- 
puter sends this code to the ICD to interrupt the transmission 
of the symbolic text record. 


PROGAM 

DESCRIPTION: 

ACTION: 


SYMBOLIC TEXT DISPLAY 

1 . The ICD sends \3E { text string } < CR > which may contain 
one or more "\3X{ parameter} ” within the text line, to the 
host computer when it displays a parameter by a symbol. 

2. The host computer enters all data before <CR> into the 
input buffer and acts on the following: 

a) If \3X( parameter} cannot be found in the input buffer, 
the host computer displays the contents of the input 
buffer already converted to symbols, sends \F8<CR> 
to the ICD, and then returns to the IDLE program. 

b) If \3J<{ parameter) is found, the host computer search- 
es the symbol table for { parameter } . 


If { parameter } cannot be found in the symbol table, the 
host computer returns to "a” (above) after converting 
\3X{ parameter) to {parameter}. 

If {parameter} is found in the symbol table, the host 
computer returns to "a” (above) after converting \3X 
{ parameter ) to a symbol. 
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Section 4 


LOCAL MODE: 

PROGRAM: 


DESCRIPTION: 

ACTION: 


TERMINAL CONTROL OF THE ICD (WITH HOST DATA FILES) 


IDLE 



r — — 

r 

JL 


1 

CONSOLE/ 


COMMAND 


FUNCTION 

REMOTE 


REQUEST 


ANALYSIS 

PROGRAM 


PROGRAM 


PROGRAM 




OBJECT 

FILE/LOAD 

VERIFY 

PROGRAM 


l 


OBJECT 

FILE 

SAVE 

PROGRAM 




ILLEGALTZ” 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 


SYMBOLIC 


COMMAND 

NUMERAL 


TEXT 


& TEXT 

CONVERSION 


DISPLAY 


EXECUTION 

PROGRAM 


PROGRAM 


PROGRAM 


LOCAL MODE 
PROGRAM 
FLOWCHART 


■ 

CONSOLE 

COMMAND 

INPUT/OUTPUT] 

PROGRAM 




CONSOLE 

CHARACTER 

READ 

PROQRAM 


CONSOLE 

TEXT 

READ 

PROGRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROGRAM 


This program acts as the main intermediary program (transfer- 
ring instructions and text only) between the ICD and the sub- 
programs (Command Request and Function Analysis). 

1. The host computer waits for an input from the ICD (The host 
system must have an input buffer to hold the input code from 
the ICD) 

2. The host computer receives one line of data and places it 
in the input buffer. 

3. The host computer then executes one of the following pro- 
grams depending on the code it receives: 

Code Received Program Executed 

\ FO { text } < CR > COMMAND REQUEST 
any other FUNCTION ANALYSIS 
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COMMUNICATION PROTOCOL 


PROGRAM: 


COMMAND REQUEST-CONSOLE 


IDLE 

PROGRAM 



r -*"T 

j ^ 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

r::;e."REAP ... 


READ 

program 


PROGRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROGRAM 


ICD Host Computer System 


\F0{text)<CR> ^ 


CONSOLE CHARACTER READ SEQUENCE 
CONSOLE TEXT READ SEQUENCE 
CONSOLE CHARACTER WRITE SEQUENCE 
CONSOLE TEXT WRITE SEQUENCE 


4 \F1 <CR> 
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ORIGIN ACTION: These sequences allow commands to input to the ICD through 

the console terminal in the LOCAL mode. 

ICD \ FO ( text ] COMMAND INPUT STATUS WAIT CODE. This code is sent to 

< CR > the host computer before the ICD displays a prompt ( >). 

Optional sequences: CONSOLE CHARACTER READ/WRITE SEQUENCE or 

CONSOLE TEXT READ/WRITE SEQUENCE 

HOST \F1 <CR> CONSOLE COMMAND INPUT REQUEST CODE. The ICD 

outputs a prompt to the console screen after receiving this 
code. 


Section 4 


COMMUNICATION PROTOCOL 


PROGRAM : 




COMMAND REQUEST - REMOTE 



CONSOLE/ 

REMOTE 

PROGRAM 


COMMAND 

REQUEST 

PROGRAM 


FUNCTION 

ANALYSIS 

PROGRAM 


OBJECT 


OBJECT 

FILEJLOAO 


FILE 

VERIFY 


SAVE 

PROGRAM 


PROGRAM 


ILLEGALTZ” 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 1 
NUMERAL 
CONVERSION 
PROGRAM 


l 


SYMBOLIC 

TEXT 

DISPLAY 

PROGRAM 


i 


COMMAND 
ft TEXT 
EXECUTION 
PROGRAM 


LOCAL MODE 
PROGRAM 
FLOW CHART 


CONSOLE 

COMMAND 

INPUT/OUTPUTl 

PROGRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

READ 


READ 

PROGRAM 


PROGRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROGRAM 


ICD Host Computer System 


\F0{text) <CR> ► 


CONSOLE CHARACTER READ SEQUENCE 
CONSOLE TEXT READ SEQUENCE 
CONSOLE CHARACTER WRITE SEQUENCE 
CONSOLE TEXT WRITE SEQUENCE 


i \F9 1 command J < OR > 
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ORIGIN ACTION: These sequences enable the ICD to directly execute com- 
mands in the LOCAL mode. 


ICD 


\ FO { text ) COMMAND INPUT STATUS WAIT CODE. This code is sent to 

< CR > the host computer before the ICD displays a prompt ( >). 


Optional sequences: CONSOLE CHARACTER READ/WRITE SEQUENCE or 

CONSOLE TEXT READ/WRITE SEQUENCE 


HOST \F9 REMOTE COMMAND REQUEST RECORD. This record 

{ ICD command ) < CR > allows the ICD to execute commands directly. When the ICD 

receives this record from the host computer, it displays a 
prompt and the (command ) on the console screen. 


PROGRAM 

DESCRIPTION: COMMAND REQUEST-CONSOLE/REMOTE 


ACTION: 1. The ICD requests a command by sending xFO(text) <CR> 

to the host computer from the ICD. Additionally, any of the fol- 
lowing four console input/output sequences can be executed; 

a) CONSOLE CHARACTER READ PROGRAM 

b) CONSOLE TEXT READ PROGRAM 

c) CONSOLE CHARACTER WRITE PROGRAM 

d) CONSOLE TEXT WRITE PROGRAM 

2. All of the console or remote commands can be executed when 
the host computer receives \F0( text } < CR > . 

3. If console commands are used, the sequence ends with 
\ FI < CR > , and the host computer returns to the IDLE pro- 
gram. 

4. If remote commands are used, the sequence ends with 
\F9{ICD command )<CR>, and the host computer re- 
turns to the IDLE program. 
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PROGRAM: 


ACTION: 


FUNCTION ANALYSIS 


IDLE 

PROGRAM 


r 






CONSOLE/ 

REMOTE 

PROGRAM 


COMMAND 

REQUEST 

PROGRAM 


FUNCTION 

ANALYSIS 

PROGRAM 


i — r 1 — "i*' — — — 1 r — — 1 

1 i i ' n i 1 I i 1 I i 1 l i—*— | i * 


OBJECT 

FILE/LQAD 

VERIFY 

PROGRAM 


OBJECT- 

FILE 

SAVE 

PROGRAM 


ILLEGAL/*?” 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOLIC 

TEXT 

DISPLAY 

PROGRAM 


COMMAND 
fit TEXT 
EXECUTION 
PROGRAM 

• 


i 

♦ 


-t- 


l 

i 

+ 


LOCAL MODE 
PROGRAM 
FLOW CHART 


1 

CONSOLE 

COMMAND 

INPUT/OUTPUT 

PROGRAM 


CONSOLE 


CONSOLE 


CONSOLE F 


CONSOLE 

CHARACTER 


TEXT 


CHARACTER 


TEXT 

READ 


READ 


WRITE 


WRITE 

PROGRAM 


PROGRAM 


PROGRAM 


PROGRAM 


1. The host computer places one line of data (received from 
the ICD) into the input buffer and then analyzes the data. 


2. The host computer then executes one of the following pro- 
grams based on the contents of the input buffer: 

Input Buffer Contents Program Executed 


\ 00 { filename ) < CR > 
or \ 02 { filename }<CR> 

\01 (filename) <CR> 
or \ 03 ( filename )<CR> 

\ 10 ( filename ) < CR > 
or \ 12 (filename }<CR> 

\ 43 { parameter ) < CR > 

\44<CR> 

\2X { symbol )<CR> 

\ 3X { parameter ) ( text ) < 


FILE LOAD 

FILE VERIFY 

FILE SAVE 

"Z" COMMAND 
QUIT 

SYMBOL CONVERSION 

> SYMBOLIC TEXT 
DISPLAY 
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PROGRAM: 


ORIGIN ACTION: 


ICD \ 00 (filename) 
<CR> 
or \02(filename) 
<CR> 


OBJECT FILE LOAD/VERIFY 



r 


1 




CONSOLE/ 

REMOTE 

PROGRAM 


COMMAND 

REQUEST 

PROGRAM 


FUNCTION 

ANALYSIS 

PROGRAM 


OBJECT 

FILE/LOAD 

VERIFY 

PROGRAM 


i 


OBJECT 

FILE 

SAVE 

PROGRAM 


ILLEGALTZ” 

COMMAND 

PROGRAM 




SYMBOL/ 

QUIT 


NUMERAL 

PROGRAM 


CONVERSION 



PROGRAM 

■t 

+ 


SYMBOLIC 

TEXT 

DISPLAY 

PROGRAM 


i 


COMMAND 
& TEXT 
EXECUTION 
PROGRAM 


i 


LOCAL MODE 
PROGRAM 
FLOWCHART 


CONSOLE 

COMMAND 

INPUT/OUTPUTj 

PROGRAM 


CONSOLE 

CHARACTER 

READ 

PROGRAM 


CONSOLE 


CONSOLE 

TEXT 


CHARACTER 

READ 


WRITE 

PROGRAM 


PROGRAM 


CONSOLE 

TEXT 

WRITE 

PROGRAM 


An object file is sent from the host computer in response to a 
LOAD/VERIFY request from the ICD. 

INTEL HEX LOAD REQUEST RECORD or 
S FORMAT LOAD REQUEST RECORD. This record is sent to 
the host computer when the ICD loads an object file. 
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ICD 

\CM (filename) 
<CR> 
or \ 03 (filename) 
<CR> 

INTEL HEX VERIFY REQUEST RECORD or 

S FORMAT VERIFY REQUEST RECORD. This record is sent to 
the host computer when the ICD verifies an object file with the 
memory. 

HOST 

( record )<CR> 

OBJECT FILE RECORD. This Intel Hex or S format record is 
sent to the ICD from the host computer. This record may not 
contain any control code, and must end with < CR > . 

ICD 

\F8<CR> 

OBJECT RECORD REQUEST CODE. This code is sent to the 
host computer to request an Intel Hex or S format record. 

ICD 

\F6<CR> 

OBJECT RECORD RE-TRANSMISSION REQUEST CODE. This 
code is used when the ICD requests the host computer to re- 
transmit the object file. NOTE: Most re-transmission requests 
are ca used by an error occurring in the check sum of the Intel 

Hex or S format record. 

ICD 

\F7<CR> 

OBJECT FILE TRANSMISSION INTERRUPT CODE. When the 
host computer receives this request, it stops the LOAD/VER- 
IFY sequence. 

Optional Sequences: 

CONSOLE CHARACTER READ/WRITE SEQUENCE or 
CONSOLE TEXT READ/WRITE SEQUENCE 

HOST 

\F1<CR> 

LOAD/VERIFY END CODE. The host computer sends this 
code to the ICD (after closing the file) if the file records are 
exhausted. 

HOST 

\ F7 < CR > 

LOAD/VERIFY SEQUENCE ABORT INDICATION CODE. The 
host computer uses this code to inform the ICD that it is abort- 
ing the object LOAD/VERIFY sequence. 
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PROGRAM 

DESCRIPTION: 

ACTION: 


OBJECT FILE LOAD/VERIFY 

1. The ICD sends \0X { filename J < CR > to the host computer 
to load or verify a user program. The host computer then 
opens the requested program file. 

2. The host computer reads the Intel Hex or S format records 
from the file and acts on the following: 

a) If an error occurs when opening or reading the file, the • 
host computer sends \F7 < CR > to the ICD and returns 
to the IDLE program. 

b) If no error is detected, the host computer sends the Intel 
Hex or S format record to the ICD and then waits for 
\F8<CR> from the ICD. 

If the host computer receives \ F8 < CR > , it then reads 
the Intel Hex or S format record. If the code is \ F7 
< CR > , the host computer sends \F8 < CR > after clos- 
ing the file and then returns to the IDLE program. 

If the code is \F6<CR>, the host computer waits for 
\F8<CR> after re-transmitting the Intel Hex or S for- 
mat record to the ICD. 

c) If there is no record to send when \F8 < CR > is receiv- 
ed from the ICD, the host computer closes the file, sends 
\F1 < CR > to the ICD, and then returns to the IDLE pro- 
gram. 


ICD-278 for Z80 


ZAX Corporation 4-33 



COMMUNICATION PROTOCOL 


Section 4 


PROGRAM: OBJECT FILE SAVE 



LOCAL MODE 
PROGRAM 
FLOW CHART 


CONSOLE 

COMMAND 

INPUT/OUTPUT 

PROGRAM 


CONSOLE 


CONSOLE 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 


CHARACTER 


TEXT 

READ 


READ 


WRITE 


WRITE 

PROGRAM 


PROGRAM 


PROGRAM 


PROGRAM 


ORIGIN ACTION: When this command is issued, the host computer receives an 

object program and creates a file. 


ICD 


\ 10 (filename) 
<CR> 
\ 12 (filename) 
<CR> 


INTEL HEX SAVE REQUEST RECORD or 
S FORMAT SAVE REQUEST RECORD. This record is sent by the 
ICD to request the host computer to save a file. The ( filename ) 
field may be used for a user-defined save message 
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HOST 

\F8<CR> 
(at file write) 

OBJECT RECORD REQUEST INDICATION CODE. This code 
is sent to the ICD from the host computer to request an Intel 
Hex or S format record. 

ICD 

( record ]<CR> 

OBJECT FILE RECORD. This Intel Hex or S format record is sent 
to the host computer. 

Optional Sequences: 

CONSOLE CHARACTER READ/WRITE SEQUENCE or 
CONSOLE TEXT READ/WRITE SEQUENCE 

HOST 

\F8<CR> 

OBJECT RECORD REQUEST INDICATION CODE. The host 
computer sends this code to the ICD to request a record. 

HOST 

\F6<CR> 

OBJECT RECORD RE-TRANSMISSION REQUEST CODE. This 
code requests the ICD to re-transmit an object code. 

ICD 

\F1 <CR> 

FILE END CODE. The ICD sends this code to the host computer 
when the transmission of the file records has been exhausted. 
The host computer ends the object save sequence by sending 
\F8<CR> after closing the file. 

HOST 

\F7<CR> 

SAVE SEQUENCE ABORT INDICATION CODE. The host com- 
puter informs the ICD that it is aborting the object save 
sequence. 

HOST 

\F8<CR> 
(at file close) 

FILE CLOSE END CODE. This code is sent to the ICD from the 
host computer when the file close is successful. 

HOST 

\F7<CR> 

SAVE SEQUENCE ABORT INDICATION CODE. This code indi- 


cates that the host computer has stopped the object save se- 
quence. 
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\1X{filename)<CR> 

<CR> 


{ Intel HEX record ) < CR> i 
or { S format record ) < CR > 


Host Computer System 


\F8<CR> 


, 

4 

(designated file make] 

J 


(write Intel HEX or S format record) 


CONSOLE CHARACTER READ SEQUENCE 
CONSOLE TEXT READ SEQUENCE 
CONSOLE CHARACTER WRITE SEQUENCE 
CONSOLE TEXT WRITE SEQUENCE 


( Intel Hex record } < CR > 
or | S format record ) < CR > 

( Intel HEX record ) < CR> 
or (S format record) <CR> 


\PI<CR> 
or \F7<CR> 


\F8<CR> 


-\F6<CR> 


(when receive record error) 

j 


(write Intel HEX or S format record) 

i 


\F8<CR> 


(designated file close) 

i 

4 \F8<CR> or \F7 <CR> ' 

(to command input request sequence etc) 
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PROGRAM DESCRIPTION: 

ACTION: 


OBJECT FILE SAVE 

1. The ICD sends \ IX { filename }<CR> to the host computer 
when saving a user program. The host computer then opens 
the selected user file. 

If the file does not open, the host computer sends \F7<CR> 
to the ICD and returns to the IDLE program. If the file opens, 
the host computer sends \F8<CR> to the ICD. 

2. The host computer waits for an Intel Hex or S format record 
from the ICD. If it receives \F1 <CR> from the ICD, the host 
computer sends \F8<CR> after closing the user program 
file and returns to the IDLE program. 

After receiving an Intel Hex or S format record, the host com- 
puter then executes a file write of the record received from the 
ICD. If an error occurs during the file write operation, the host 
computer closes the user program file, sends \F7 < CR > to the 
ICD, and returns to the IDLE program. 

If an error occurs in a sum check, the host computer sends 
\F6< CR> and waits for the Intel Hex or S format record to be 
retransmitted from the ICD. The host computer then waits for 
the next Intel Hex or S fsormat record (sending \F8<CR> to 
the ICD) if no error occurs during the file write. 
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PROGRAM: 


ORIGIN ACTION: 

ICD \ 43 ( parameter ) 
<CR> 

HOST °\F8<CR> 


ILLEGAL/“Z” COMMAND 


IDLE 

PROGRAM 



LOCAL MODE 
PROGRAM 
FLOWCHART 


I 

CONSOLE 

COMMAND 

INPUT/OUTPUT 

PROGRAM 


i 


CONSOLE 

CHARACTER 

READ 

PROGRAM 


CONSOLE 

TEXT 

READ 

PHOQRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROGRAM 


ICD 

Host Computer System 

v ^ t command 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

1 

11 

A 

ct 

O 

V 

I & parameter 

i 


Illegal command 


”Z" command procedure 


4 \F8<CR> or \F7<CR> 


This sequence is used to process an ILLEGAL or "Z” command 
according to the parameters sent from the ICD. The ILLEGAL 
command is a command not defined in the ICD, but is interpret- 
ed and processed by the host computer. 

ILLEGAL COMMAND/"Z” COMMAND RECORD. This record 
is sent to the host computer to process the ILLEGAL/ 1 'Z” com- 
mand. 

ILLEGAL COMMAND/"Z" COMMAND NORMAL END CODE. 
This code is sent to the ICD when the ILLEGAL/''Z” command 
has been processed successfully. 
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COMMUNICATION PROTOCOL 

HOST 

\F7<CR> 

ILLEGAL COMMAND/"Z” COMMAND ABNORMAL END 
CODE. This code is sent to the ICD when the ILLEGAL/"Z” com- 
mand has not been processed successfully. 

PROGRAM DESCRIPTION: 

“Z” COMMAND 


ACTION: 

1. The ICD sends \ 43 { parameter) <CR> (and the specified 
“Z" command) to the host computer. 



2. The host computer then performs the specified "Z” command 
and acts on the following: 


If an error is contained in the “Z” command specification, the 
host computer sends \ F7 < CR > to the ICD and then returns 
to the IDLE program. 

If no error is detected, the host computer sends \F8<CR> 
to the ICD and then returns to the IDLE program. 

“Z" commands available with ZICE Z80 (V2.4) include: 


ABBREVIATION NAME FUNCTION 


HE 

Help 

Displays the command list. 

DEF 

Define 

Adds a new symbol to the ZICE 
symbol table. 

SL 

SLoad 

Reads a symbol file on diskette 
into the ZICE symbol table. 

DEL 

Delete 

Deletes a symbol from the ZICE 
symbol table. 

SS 

SSave 

Stores the ZICE symbol table on a 
diskette as the symbol file. 

SH 

Show 

Displays the names and values of 
symbols in the ZICE symbol table 
and their qualities. 

LOG 

Log 

Stores everything displayed into a 
specified file. 

BA 

Batch 

Executes a file of ICD commands. 
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PROGRAM: 


ORIGIN ACTION: 


ICD \44<CR> 


QUIT 



r 

1 

— L 


1 

■ 

CONSOLE/ 


COMMAND 


FUNCTION 

REMOTE 


REQUEST 


ANALYSIS 

PROGRAM 


PROGRAM 


PROGRAM 


OBJECT 

FILE/LOAD 

VERIFY 

PROGRAM 


OBJECT 

FILE 

SAVE 

PROGRAM 

1 

♦ 


ILLEGAU-Z” 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


l 


SYMBOLIC 

TEXT 

DISPLAY 

PROGRAM 


COMMAND 
& TEXT 
EXECUTION 
PROGRAM 


I 


LOCAL MODE 
PROGRAM 
FLOWCHART 




CONSOLE 

COMMAND 

INPUT/0UTPUT| 

PROGRAM 


CONSOLE 


CONSOLE 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 


CHARACTER 


TEXT 

READ 


READ 


WRITE 


WRITE 

PROGRAM 


PROGRAM 


PROGRAM 


PROGRAM 


ICD 


Host Computer System 

\44<CR> 

> 

| 



i 



(return to OS) 


The host computer returns to the operating system (OS) indi- 
cated by the ICD's code. (The ICD "HOST ON” mode is also 
cancelled.) 

QUIT RECORD. 
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COMMUNICATION PROTOCOL 


PROGRAM: SYMBOL/NUMERAL CONVERSION 


IDLE 

PROGRAM 



LOCAL MODE 
PROGRAM 
FLOW CHART 


CONSOLE 

COMMAND 

INPUT/OUTPUT 

PROGRAM 


l 


CONSOLE 

CHARACTER 

READ 

PROGRAM 




CONSOLE 

TEXT 

READ 

PROGRAM 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROQRAM 


ICD 


Host Computer System 


\2X { symbol }<CR> i- ^ 




CONSOLE CHARACTER READ SEQUENCE 
CONSOLE TEXT READ SEQUENCE 
CONSOLE CHARACTER WRITE SEQUENCE 
CONSOLE TEXT WRITE SEQUENCE 


^ — i \F90 {number} H<CR> 

or \F1<CR> 
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ORIGIN ACTION: 

This sequence is used when the host computer requests a sym- 
bol/numeral conversion. 

ICD \2X{ symbol) 

<CR> 

SYMBOL/NUMERAL CONVERSION REQUEST RECORD. This 
record is sent to the host computer requesting the numeric con- 
version of a symbol. (The ICD sends ( symbol ) < OR > including 
“ which means a symbol.) 

Optional Sequences: 

CONSOLE CHARACTER READ/WRITE SEQUENCE or 

CONSOLE TEXT READ/WRITE SEQUENCE 

HOST \F9 0 (number 
(hexadecimal ASCII) J H 
<CR> 

NUMERIC RECORD. This record is sent to the ICD when the 
symbol received has been converted to a numeral. (The host 
computer attaches 0 to the head of the converted value and 
"H"<CR> at the end.) 

HOST \F1 <CR> 

SYMBOL/NUMERAL CONVERSION ERROR CODE. This code 
is sent by the host computer when the symbol chosen cannot be 
converted to a numeral. 

PROGRAM DESCRIPTION: 

SYMBOL CONVERSION 

ACTION: 

The ICD sends \ 20 ( symbol ) < CR > to the host computer when 
the symbol/number conversion is executed. The host computer 
then searches the symbol table for the [ symbol ) received from 
the ICD to convert to a numeral, and acts on the following: 


1. If the conversion is successful, the host computer sends the 
numeral to the ICD with "0" attached at the head and "FI" 
followed by <CR> at the end, and then returns to the 

IDLE program. 


2. If the conversion is unsuccessful, the host computer sends 
\ FI < CR > to the ICD and returns to the IDLE program. 
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COMMUNICATION PROTOCOL 


PROGRAM: 



ACTION: 


NUMERAL CONVERSION 


IDLE 

PROGRAM 



LOCAL MODE 
PROGRAM 
FLOWCHART 


CONSOLE 

COMMAND 

INPUT/OUTPUT 

PROGRAM 


i 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

READ 


READ 

PROGRAM 


PROGRAM 


CONSOLE 

CHARACTER 

WRITE 

PROGRAM 


i 


CONSOLE 

TEXT 

WRITE 

PROGRAM 


1. The ICD sends \3E{ text which includes \3X (parameter) ) 
<CR> to the host computer when the numeral/symbol 
conversion program is executed. 
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Section 4 


2. The host computer enters all data before <CR> into the ICD 
input buffer. 

3. The host computer then searches the input buffer for \3X 
( parameter ) and executes one of the following: 

a) If \3X( parameter) is not found, the host computer sends 
out the text— attaching \ 80 to the front and < CR > to the 
end of the text— and then waits for \F8<CR> from the 
ICD, When \ F8 < CR > is received from the ICD, the host 
computer sends \ FI to the ICD and returns to the IDLE 
program. 

b) If \3X( parameter) is found, the host computer searches 
the symbol table for f parameter) . If ( parameter) is not 
found in the symbol table, the system converts \3X( para- 
meter) to (parameter), and returns to“3” (above). If 
(parameter) is found in the symbol table, the system 
converts \3X( parameter) to a symbol. 
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PROGRAM: 


SYMBOLIC TEXT DISPLAY 


IDLE 

PROGRAM 


1 


1 




CONSOLE/ 


COMMAND 


FUNCTION 

REMOTE 


REQUEST 


ANALYSIS 

PROGRAM 


PROGRAM 


PROGRAM 


OBJECT 

FILE/LOAD 

VERIFY 

PROGRAM 


OBJECT 

FILE 

SAVE 

PROGRAM 




ILLEGALTZ" 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


i 


SYMBOLIC 

TEXT 

DISPLAY 

PROGRAM 


COMMAND 
& TEXT 
EXECUTION 
PROGRAM 




LOCAL MODE 
PROGRAM 
FLOW CHART 


I CONSOLE 
COMMAND 
INPUT/OUTPUT| 
PROGRAM 

■ 
i 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

READ 


READ 

PROGRAM 


PROGRAM 


CONSOLE 

CHARACTER 

WRITE 

PROGRAM 


CONSOLE 

TEXT 

WRITE 

PROGRAM 


ICD 

\3E (text) 

\3X (parameter) 
(text) <CR> 



Host Computer System 


CONSOLE CHARACTER READ SEQUENCE 
CONSOLE TEXT READ SEQUENCE 
CONSOLE CHARACTER WRITE SEQUENCE 
CONSOLE TEXT WRITE SEQUENCE 


I- -■‘sj I \80(Text) <CR> 

r 

i 

i 


(display text) 

' ¥ \F8<CR> ¥ 

or \F7<CR> 

1 \Ft <CR> 
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Section 4 


ORIGIN ACTION: The parameters sent from the ICD are displayed on the con- 
sole screen after being converted to symbols. 


ICD \3E 

(text which includes \3X ) 
<CR> 


NUMERAL/SYMBOL CONVERSION RECORD. This record 
tells the host computer to convert a numeral to a symbol. (\3X 
is a header.) 


Optional Sequences : CONSOLE CHARACTER READ/WRITE SEQUENCE or 

CONSOLE TEXT READ/WRITE SEQUENCE 


HOST \ 80 (text) 

(change to symbol) 
<CR> 


NUMERAL/SYMBOL RECORD. The host computer sends this 
record if the numeral is successfully converted to a symbol. 


ICD \ F8 < CR > DISPLAY END CODE. This code is sent to the ICD when the 

symbol display and text in the symbolic text record have been 
completed. 

HOST \H <CR> NUMERAL/SYMBOL CONVERSION END CODE. The host 

computer sends this code to the ICD to end the sequence. 
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PROGRAM: COMMAND AND TEXT EXECUTION 



CONSOLE 


CONSOLE 


CONSOLE 


CONSOLE 

CHARACTER 


TEXT 


CHARACTER 


TEXT 

READ 


READ 


WRITE 


WRITE 

PROGRAM 


PROGRAM 


PROGRAM 


PROGRAM 



ICD 


Host Computer System 

\8 0 (text) <CR> I — r 

=> 




1 



♦ 



(print out file writ© etc,) 

i 

i 

i 

i 

i 
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ORIGIN ACTION: The ICD outputs the command and the result of its execution to 

the host computer. The host computer can then output the text 
to a printer or onto a file. NOTE: In the LOCAL mode, the PRINT 
ON command is treated as an Illegal/"Z" command after the 
HOST ON command is issued. 

ICD \ 80 { text } COMMAND EXECUTION TEXT. Outputs one line of text after 

< CR > the execution of the command by the ICD. 

HOST \ F8 < CR > TEXT RECEPTION COMPLETE CODE. This code is transmit- 

ted to the ICD when the host computer has received the text 
and completed the output execution. 



Section 4 


COMMUNICATION PROTOCOL 


PROGRAM: 


ACTION: 


CONSOLE COMMAND INPUT/OUTPUT 



CONSOLE/ 


COMMAND 


FUNCTION 

REMOTE 


REQUEST 


ANALYSIS 

PROGRAM 


PROGRAM 


PROGRAM 

U — -- 

r 


i 

i 

i 


OBJECT 


OBJECT 

FILE/LOAD 


FILE 

VERIFY 


SAVE 

PROGRAM 


PROGRAM 

i 

4 - 

l 

♦ 


ILLEGAL/***" 

COMMAND 

PROGRAM 


QUIT 

PROGRAM 


SYMBOL/ 

NUMERAL 

CONVERSION 

PROGRAM 


SYMBOUC 

TEXT 

DISPLAY 

PROGRAM 


i 


COMMAND 
4 TEXT 
EXECUTION 
PROGRAM 


i 


LOCAL MODE 
PROGRAM 
FLOW CHART 


CONSOLE 

COMMAND 

INPUT/OUTPUTj 

PROGRAM 

r 
i 


CONSOLE 

CHARACTER 

READ 

PROGRAM 


CONSOLE 

TEXT 

READ 

PROGRAM 


1 - 

CONSOLE 


CONSOLE 

CHARACTER 


TEXT 

WRITE 


WRITE 

PROGRAM 


PROGRAM 


There are four input/output sequences available when the ICD 
operates in the LOCAL mode: 

1) CONSOLE CHARACTER READ 

2) CONSOLE TEXT READ 

3) CONSOLE CHARACTER WRITE 

4) CONSOLE TEXT WRITE 
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Section 4 


PROGRAM: 


CONSOLE CHARACTER READ 


IDLE 

PROGRAM 



ICD Host Computer System 

*“ — ————————— ^ \8A<CR> 


(input a character from console) 

4 

\ F9 ( character ) < CR> I 
or \F8<CR> 
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COMMUNICATION PROTOCOL 


ORIGIN ACTION: The host computer uses this sequence to request a single 

character of data from the console through the ICD. 

ICD n 8A CONSOLE KEY INPUT REQUEST CODE. 

HOSTxF9( input character) CONSOLE INPUT CODE. This code is sent to the host com- 
<CR> puter if there is an input character. The input character and 
< CR > are then sent to the host computer. (The ICD does not 
echo back the console input.) 

HOST \F8<CR> NO CONSOLE KEY INPUT CODE. The ICD sends this code to 

the host computer if there is no console input. 
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PROGRAM: 


CONSOLE TEXT READ 


IDLE 

PROGRAM 



ICD 

r «- 

i 

i 

i 

a 

i 

i 

i 

(Input a line from console) 

^ \F9 {text} <CR> [ 


Host Computer System 

\8 8 <CR> 
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COMMUNICATION PROTOCOL 


ORIGIN ACTION: This sequence is used when the host computer requests the 

ICD to input one line of data. 

HOST \ 88 < CR > DATA INPUT REQUEST CODE. The host computer sends this 

code to the ICD to request one line of data. 

ICD \F9( line of data } DATA INPUT CODE. This code is sent to the host computer 
< CR > along with the line of data entered from the console terminal. 

The maximum number of input characters is limited to 255; 
subsequent characters are discarded. 
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Section 4 


PROGRAM: 


CONSOLE CHARACTER WRITE 


IDLE 

PROGRAM 



ICD 


Host Computer System 


r — - ^ i \8 2 {character} <CR> 

! 

i 

(output character(s)) 

L \F8<CR> *- 

or \F7<CR> 
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COMMUNICATION PROTOCOL 


ORIGIN ACTION: This sequence is used when the host computer requests the 

ICD to output n characters to the console. 

HOST \ 82 ( characters ) N CHARACTERS OUTPUT REQUEST CODE. The host com- 

<CR> puter sends this code to the ICD, requesting the output of 
n characters to the console. The ICD then sends [ characters ) 
to the console, without being followed by a < CR> < LF > . 

ICD \F8<CR> N CHARACTERS OUTPUT END CODE. This code is sent to 

the host computer from the ICD when the n-character output to 
the console is completed. 


ICD-278 for Z80 


ZAX Corporation 4-55 



COMMUNICATION PROTOCOL 


Section 4 


PROGRAM: CONSOLE TEXT WRITE 


IDLE 

PROGRAM 



ICD Host Computer System 


S ~l \8 0 ( text } <CR> 


(textdisplay record] 

U \F8<CR> ► 

or \F7<CR> 


ORIGIN 

ACTION: 

This sequence is used when the host computer requests the 
ICD to output one line of data to the console. 

HOST 

\80(text] 

<CR> 

DATA OUTPUT REQUEST RECORD. This record requests the 
ICD to output one line of data to the console. The ICD outputs 
( text ) < CR > to the console and then follows it with a line feed. 

ICD 

\F8<CR> 

CONSOLE OUTPUT END CODE. This code is sent to the host 
computer when the sequence is completed. 
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COMMUNICATION PROTOCOL 


NUMBER CONVERSION CODES 
ICD278/ZBO 


number change code 

format 

description 

\20 

\ 20 (. symbol )<CR> 

address symbol 

\21— \2F 

not used 



NUMBER CONVERSION CODES 
ICD278/I8085 


number change code 

format 

description 

\20 

\20(. symbol )<CR> 

address symbol 

\21-\2F 

not used 



NUMBER CONVERSION CODES 
ICD178/I8086, 18088 


number change code 

format 

description 

\20 

\ 20 { .symbol } < CR > 

physical address symbol 

\21 

not used 


\22 

\22 (.symbol )<CR> 

segment address symbol 

s23 

not used 


\24 

s24xxxx:(. symbol) 
<CR> 

offset address symbol 
(XXXX is current segment) 

\25-\2F 

not used 



NUMBER CONVERSION CODES 
ICD178/I8048 


number change code 

format 

description 

s20 

s20 (. symbol )<CR> 

address symbol 

n21— \2F 

not used 
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COMMUNICATION PROTOCOL 

Section 4 

NUMBER CONVERSION COOES 

ICD178/6800, 68010, 68008 
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COMMUNICATION PROTOCOL 


SYMBOL CONVERSION CODES 
ICD278/I8085 
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COMMUNICATION PROTOCOL 


Section 4 


SYMBOL CONVERSION COOES 
IC0I78/I8O86, 18088, 180186, 180188 


symbol change code description 


physical 

header 


logical 

header 



example 


\ 3000000 90 NOP 

i ~ ii 1 

physical header address 

symbol change code 


\ 310000: 0000 90 NOP 


logical header address 
symbol change code 



JMP \ 3 2 $ - -t 0 H 


\35— \ 36 not used 



branch displacement 
symbol change code 


MOV AL, \ 3 4 5 5 H 



number 

symbol change code 


JMP \ 378000H (or\370100H: 8000H) 



symbol change code 


MOV AL, BYTE PTR \ 39 0000H: 1000H 


variable 
logical address 
— symbol 
change code 


not used 
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COMMUNICATION PROTOCOL 


SYMBOL CONVERSION CODES 
ICDI78/I8048 
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SYMBOL CONVERSION CODES 
ICD178/6BOOO, 68010, 68008 


symbol change code 

description 

\30 

header 

\31-\33 

not used 

\34 

number 

\35 

not used 

s36 

label 

\37 

not used 

\38 

variable 

\39-\3F 

not used 


example 


\ 30000000 


- header address 
-symbol change code 


MOVE. B.\34$00,DO 


number 

symbol change code 


JMP v 36$ 00001 000. W 


label 

symbol change code 


MOVE. B DO, v 38S00001000.W 


variable 

| symbol change 

code 
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INTEL HEX OBJECT FORMAT: 


COMMUNICATION PROTOCOL 


All object files are represented by ASCII codes. This example 
shows one byte of data being converted to an ASCII hexa- 
decimal number ("0"— "9" and “A”— "F") of two digits: 

00 H "00"(3030 H ) 

9B H ”9B"(3942 h ) 

An object file is divided into units of records which include 
four types: 

(1) Data Record 

(2) End of File Record 

(3) Extended Address Record 

(4) Start Address Record 

ICD/Z80, ICD/i8085, and ICD/8048 use Data and End Record 
only. 


One record is formatted as shown below: 


□ 

XX 

xxxx 

XX 


0 

0 

I 

1 

i 

1 

i 


l 

© 

© 


© 

© 

© 


yj j X v.v>\jWxva 

"" (3A h ) 

Shows the beginning of an Intel Hex object record. The informa- 
tion preceding this mark is treated as a comment. 

( 2 ) Load address 

"00'— FF" (3030 H -4646 H ) 

Shows the number of data bytes contained in field ©. 

(3) Code address 

"OOOO'-FFFF" (30303030 h — 46464646 h ) 

Shows the location address where a program or data is in- 
tended to be loaded. Normally contains "0000” as a dummy 
record. 
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@ Record type 
Shows type of record: 

"00" (3030j_|] Data record 
“01" (3031 H ) End of File record 

© Data 

Contains data bytes equal to the record length. (This field void 
if the record length is "00.”) 

© Check Sum 

2's complement of the value (one byte: carry ignored) of the 
total starting with the record length and the last data. NOTE: 
Addition is made after the ASCII hexadecimal number of two 
digits has been converted to a 1-byte binary number. 

Example: 

:020000020100FB 

:20000000081000D00525A58608900040000CAOOBAD95FFF4DF9AE82DA728FFD4FF2F808384 

:OE0020000818001088A8A58B040000B0000490 

:020000020200FA 

:200 00000080 00 00 0052EA1050A8401DOOOOBOOOEAF1DFFBOFFBBA80DAF38DFFSFF4FE008E1 

:20002000081000D008A1AS06000100D000000007AD05FFCODFEAE125AS85FFF2FFOF3009FD 

:0400000301000000F8 

:00000001FF 

iH REWWicv; lillb IfcHJUIU lb UStJU. LU S11UW d yiuyidlll U1 Udld. 

Example: 

: 10 0000 00 004992D B246D B6F F4891D A236C B5F E47 B8 

111 1 X -1 

0© © ® © © 

0 Record mark 
(3A H ) 

© Record length 
“10" (3130 h ) 

Shows data of 16 bytes contained in the data field ©. 

© Load address 

"0000" (30303030 h ) 

Indicates that data in field © is loaded starting at address 

0000 H . 
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END OF FILE RECORD: 


COMMUNICATION PROTOCOL 


@ Record type 
"00" (3030 h ) 

Shows that record is a data record. 

© Data 

"0049 ..." (30303439^ . . . ) 

Data in this case: 00 H -49 H -92 h • • • 

© Check sum 
"B8" (4238 h ) 

This record shows the end of an object file. 

Example: 

: 00 0000 01 F F 
i l i i l 
©CD © ® © 

© Record mark 

(3A H ) 

(2) Record length 
"00" (3030 h ) 

Shows the data field does not exist. 

© Load address 

"0000" (30303030 h ) 

Normally, “0000” is entered as a dummy address (though this ad- 
dress may be used as a start address if no start address record 
is found). 

@ Check sum 
"FF" (4646 h ) 

NOTE: When using the LOAD or VERIFY commands, the end 
of the object file is determined by the end of record. 
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EXTENDED ADDRESS 
RECORD: 


This record shows the segment address where data is loaded in 
the data record subsequent to this record. 

Example: 

: 02 0000 02 0020 DC 
4 4 4 4 4 4 

©@ © (D © © 

© Record mark 

(3A h ) 

© Record length 
"02" (3032 H ) 

Shows that two bytes of data are contained in the data field in ©. 

© Load address 

"0000" (30303030 h ) 

Contains "0000" as a dummy, though this field is ignored in this 
record. (It is still required.) 

© Record type 
”02" (3032|_|) 

Shows that this record is an extended address record. 

© Segment base address 
"0020" (30303230 h ) 

Base address in this case is 0020pj. 

© Check sum 

"DC" (4443 h ) 

02H+00H+00H+02H+00H+20H=24H 
24H Two's Complement DCh 
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COMMUNICATION PROTOCOL 


START ADDRESS RECORD: This record shows the object file start address. 

Example: 

: 04 0000 03 51620005 41 
till l l 

©( 2 ) © @ © © 

0 Record mark 
(3A h ) 

© Record length 
"04" (3034 h ) 

Indicates that the data field m©contams data of four bytes. 

© Load address 

"0000" (30303030 H ) 

Contains "0000” as a dummy, though this field is not necessary 
for this record. 

0 Record type 
"03" (3033 h ) 

Shows this record is a start address record. 

© Start address 

"51620005" (3531 363230303035^) 

Start address in this case: 

Segment = 5162|_| 

Offset = 0005|_| 

© Check sum 

"41" (3431 H ) 
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S FORMAT OBJECT FILE: All object files are described by ASCII codes. In the example, 

one byte of data is shown converted to a hexadecimal number 
("0"— "9," and "A"— "F") of two digits: 

00 H "00" (3030j-j) 

9B h ”9B" (3942 h ) 

An object file is composed of the records listed below: 

(1) Data set name record 

(2) 16-bit address data record 

(3) 24-bit address data record 

(4) 32-bit address data record 

(5) Send data record count record 

(6) 16-bit address end record 

(7) 24-bit address end record 

(8) 32-bit address end record 


ICD/68000.68008.68010 uses the data records (2) and (3) and the 
end records (6) and (7) only. The record format is shown below: 


FFl 

XX XX XX 


X 

X 

i i 

i l 

l 


l 

® © 

© ® 

© 

© 


® Record mark "S” (53^) 

Indicates the start point of an object record in S format. Informa- 
tion before this mark is treated as a comment. 


(2) Record type 

Shows the type of this record. 


(1) 

"0” 

(30 H ) 

(2) 

■ <jn 

(31 

(3) 

"2" 

(32 h ) 

(4) 

"3" 

(33 H ) 

(5) 

"5" 

(35 h ) 

(6) 

tirjn 

(3?H) 

(7) 

"8" 

(38 h ) 

(8) 

"9" 

(39 h ) 


Data set name record 
16-bit address data record 
24-bit address data record 
32-bit address data record 
Send data record count record 
32-bit address end record 
24-bit address end record 
16-bit address end record 


4-68 ZAX Corporation 


ICD-278 for Z80 



Section 4 


COMMUNICATION PROTOCOL 


(3) Record length 

"00— 'FF" (3030 h -4646h) 

Shows how many bytes of data are contained in fields @ , © 
and © 

® Load address 

"OOOO-'FFFF" (30303030 h — 46464646 h ) 

or "000000—' FFFFFF" (303030303030 H -464646464646 H ) 

or "00000000—' FFFFFFFF" 

(3030303030303030 H -4646464646464646 H ) 

When used with data records, this address shows the address 
to load a program or data. When used with end records, it 
shows the restart address of the program. When used with 
data set name records (Record type "0”), the address normal- 
ly contains "0000" as a dummy data. 16-bit address, 24-bit 
address, and 32-bit address are identified by the record type. 

© Data 

Data is equal to the record length minus the load address and 
check sum. (When the number of record bytes is 00, this field 
does not exist.) 


© Check sum 

l’s complement of the total value of the bytes up to the last data 
beginning with the record length (one byte and carry are ig- 
nored). 


NOTE: Addition is made after converting an ASCII hexadecimal 
number of two digits to a binary number of one byte. 


Example: 

S006000041424333 

S214010000A14EOA405ADF02E067D00410EC1F013A05 

S21401001085C906905AFB0490E5580C0042BE00E2E2 

S214O10020A1060C41D22FO0F2A14B8EO0C4E300B21O 

S214010030D14B04A0784E4090AB470940808E10D03B 

S214010040A15D0B08721F4C504FCC4A10A41D006ACC 

S214010050E9400F005B9BOAF2F5158F1120EFOCF8B3 

S214010060A5890B10DADF08E28548060020D708RA0C 

S214010070A1C041017ADF0050A15E280406FF005AA4 


ICD-278 for Z8Q 


ZAX Corporation 4-69 



COMMUNICATION PROTOCOL 


Section 4 


DATA SET 
NAME RECORD: 

(Record type "0") 


A record to show the record name of an object file. 

Example: 

S 0 06 0000 414243 33 

111 1 1 1 

(3X2) @ @ © © 

© Record mark 
"S" (53 h ) 

© Record type 
"0"(30 H ) 

Indicates that this record is a data set name record. 

© Record length 
"06" (3036 h ) 

Shows that the total of the load address, data, and check sum is 
six bytes. 

@ Load address 

"0000" (30303030 h ) 

This record contains “0000” as a dummy, though this field is 
ignored in this record. 

© Data set name 

"414243" (343134323433 h ) 

The record name is interpreted as ASCII codes 41 jj, 42j-j, and 
43 j-j, producing "ABC." 

© Check sum 
"33" (3030 h ] 
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DATA RECORD: 

(Record type "1'— 3") 


Shows a program or data. 

Example: 

S 2 14 010000 A1 4E0A405ADF02E067D0041 0EC1 F01 3A 05 

ill l l 1 

©©© ® © © 

© Record mark 

"S" (53 H ) 

© Record type 
"2" (32 h ) 

© Record length 
"14" (3134 h ) 

Indicates that the total of the load address and check sum is 20 
bytes. 

© Load address 

"010000" (3031 30303030 h ) 

Indicates data in field (5) is loaded starting at address 01000^. 
(The number of address bits will be 16 , 24, or 32 depending 
upon the record type in field (2).) 

© Data 

7VI4E . . . 3A" (41313445 h . . . 3341 H ) 

In this case, data is Al^, 4E^j 3A^. 

© Check sum 
"05" (3035 H ) 
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Section 4 


END RECORD: 

(Record type "7 —'9") 


III i 1 

©( 2 ) ® @ © 

© Record mark 
”S" (53 h ) 

(2) Record type 
"8" (38 h ) 

Indicates this record is an end record with the 24-bit start 
address. 

© Record length 
"04" (3034 h ) 

Shows that the total of the start address and check sum is four 
bytes. (Normally, an end record does not contain the data field.) 

@ Start address 

"OiOOOO" (303130303030 h ) 

In this case, the start address is 010000^. 

© Check sum 
“FA" (4641 H ) 

NOTE: When using LOAD and VERIFY commands, the end of an 
object file is determined by the end record. 


Shows the end of an object file. 
Example: 

S 8 04 010000 FA 
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PRINCIPLES OF EMULATION 


Appendix A: Principles of Emulation, is being prepared now, 
and will be sent to you as soon as it becomes available 
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ICD Product Demonstration: 
Features & Functions 
Of The ICD 

Introduction 


Two Different Exercises! 


If this is the first time you are using a ZAX emulator, you’ve 
turned to the right place! In Appendix B, you’ll be shown two 
exercises which you can use as a product training course. By 
following the exercises presented in this appendix, you’ll not 
only demonstrate to yourself the powerful debugging capabil- 
ities of your ICD, but you’ll learn more about emulation prin- 
ciples as well. Once you’ve familiarized yourself with some 
basic command functions and applications, you can then go 
back to the Master Command Guide in Section 2 and become 
an emulation expert! 

You have two exercises to choose from in this appendix, and 
each exercise is designed to teach you something new about 
your ICD. The exercises are intended to work with whatever 
system configuration you are operating in (see "How To Con- 
nect Your ICD To Other Devices"). For example, if you’re con- 
trolling the ICD with a terminal, and not using a target system, 
first construct the system configuration for that mode (Using 
The ICD Without A Target System: Terminal Controlled), and 
then find the exercise that is intended for that configuration 
(Exercise 1: Target System Not Used). 

The system configurations and related exercises are shown 
below. 

SYSTEM CONFIGURATION EXERCISE 

Using The ICD Without A Target See Exercise 1 

System: Terminal Or Host Computer 
Control Of The ICD 

Using The ICD With A Target System: See Exercise 2 

Terminal Or Host Computer Control Of 
The ICD 
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Important! If this is the first time you are using a ZAX emulator, you should 
read through and then carry out Exercise 1: Using The ICD 
Without A Target System. This session reveals many of the 
ICD's capabilities, including performing actual emulation of a 
test program. (If you need a refresher course in emulation 
theory and practices, read through Appendix A before you try 
the exercises.) 

Entering The Commands You don’t need to know all about the command rules to use the 

ICD feature demonstration. Just carry out the instructions 
under ACTION and read the display on your terminal’s 
screen. However, you must remember to enter the exact items 
as shown in the exercise— including feature characters 
(,/ =)— and provide spaces at the appropriate places as 
shown in the instructions. 

If you make a mistake, the ICD will probably respond with an 
error message. It's usually not a big problem— just check to 
see that the proper characters, numbers, or spaces were used, 
and then re-enter the complete command statement. 
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Exercise 1: ICD Product Demonstration— Using The ICD Without A Target System. 

System Configuration: Terminal Control of the ICD. 

Operation Mode: LOCAL 

ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

PRESS: The yellow RESET 
button on the ICD and look at 
the screen. 


You’ll see the ICD’s identification 
message followed by a prompt: 

ICD-278 for Z80 V2.0 

>. 



The prompt (>) indicates that the 

ICD is waiting for a command. After 
you’ve executed a command, or 
whenever an emulation process is 
completed, a new prompt will appear. 

Now return to your terminal’s key- 
board. 

PRESS: G followed by a <cr>. 

GO 

The MONITOR lamp on the ICD goes 
off. 

PRESS :The RESET switch and 
then look at the screen. 


Nothing happened, right? That’s 
because the ICD will not respond to a 
RESET input unless the MONITOR 
lamp is lit. This condition will occur 
whenever you’re emulating a program 
as well. 

PRESS: The MONITOR button 
on the ICD to exit. 


A new prompt appears. 

PRESS: The RESET switch. 



PRESS: R (followed by a RETURN; 
enter a RETURN after each 
action is executed). 

REGISTER 

Shows status of registers. 

ENTER: F 0,2000,00 

FILL 

Fills 8K of internal memory with 00H 
(NOP instructions). It takes a few 
seconds for the ICD to do this— wait 
to see the prompt. 
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COMMAND 


ACTION 


DEMONSTRATED 

COMMENT 

ENTER: D 0,FFF and, after a few 

DUMP 

Displays contents of memory in HEX 

seconds, PRESS: the space bar 
on your terminal. 


and ASCII. 




After the space bar is pressed, the 
scrolling will stop. Alternately press 
the space bar to start and stop the 
scrolling. 

PRESS: The ESC key to exit. 

ENTER: Dl 0,F 

DISASSEMBLE 

Disassembles contents of memory 




into assembly instructions. 




Now enter a program using the in-line 
assembler. This program will be used 
in the next examples as well. 

ENTER: A 0 


The ICD responds with 0000 and 




waits for your entry. 

ICD displays: You enter: 



0000 

LD SR04000H 



0003 

LD A.2 



0005 

LD HL1000H 



0008 

LD BC2000H 



000B 

CP 1 



000D 

JP Z,15H 



0010 

LD E,0AAH 



0012 

JP 17H 



0015 

LD E,55H 



0017 

PUSH AF 



0018 

LD (HL),E 



0019 

LD A,(HL) 



001A 

CPI 



001 C 

JP NZ,0100H 



001 F 

JP PE,18H 



0022 

POPAF 


End of memory loop. 

0023 

SUB 1 



0025 

JP NZ,5 



0028 

HALT 


End of test. 

0029 

002A 

NOP 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

PRESS: The RETURN or the ESC 
key to exit the program. 

ENTER: Dl 0.29 

DISASSEMBLE 

Displays the program just entered. 



The program just entered tests 
memory from 1000H to 3000H by 
writing alternate data patterns of 55s 
and AAs. After writing to a memory 
location, a verification is made by a 
read. 



In this first example, you will use this 
program to demonstrate how break- 
points are used, and emulation 
memory manipulated. You will also 
perform a trace of the program 
memory using the real-time trace 
buffer. In the second example (still 
using the same program) you will 
trace instructions and display the 
data in a single-step and jump-step 
manner. The third example demon- 
strates the remaining principal 
commands. 



THIS IS THE START OF EXAMPLE 1. 

ENTER: B 1C OF 100 

BREAK 

Sets the location of the ERROR 
message. 

ENTER: B/A OF 22 

BREAK 

Sets a hardware (A) breakpoint. 

ENTER: B/B MW.2000 

BREAK 

Sets a hardware (B) breakpoint. 

ENTER: B S=HALT 

BREAK 

Uses the HALT code to implement 
the software breakpoint. 
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ACTION 


COMMAND 

DEMONSTRATED COMMENT 


ENTER: B S=EN 


ENTER: B 


A 

(ON) 

OF 

0022 

B 

(ON) 

MW 

2000 

C 

(ON) 

OF 

0100 

E 

(OFF) 



T 

(ON) 



S 

(EN) 

HALT 

(76H) 

w 

k 

(ON) 

t 

t 


BREAK 


BREAK 


pass count 


address 
break operation 
break status 
break identification 


Enables (EN) software (S=) break- 
points to occur. 

Displays status of the breakpoints. 
Compare with the display below: 

0 IND (0000 0000 0010 0010) 

0 IND (0010_0000_0000_0000) 

0 IND (0000_0001_0000_0000) 

0 


bit-wise physical address 
INDependent of or ARMed by event 
elapsed count 


NOTE: A, B,C = hardware break names, E = event break, T= ready timeout break, 
S = software break opcode, W= write-protect break. 


ENTER: H 

CLR 

HISTORY 

Clears the real-time trace buffer. 

ENTER: H 

BM 

HISTORY 

Sets the trigger mode of the real-time 
trace buffer (called up using the 
HISTORY command) to the Begin 
Monitor (BM) mode. 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: H 

HISTORY 

Displays the trace status of the real- 
time trace buffer. Compare with the 
display below: 



Clock Counter = 00000000/0 

Storage Mode = BM 2045 

Storage Size = 0 



"Clock Counter” shows the number 
of clocks (T-states) since the HISTORY 
command was cleared. "Storage 

Mode” shows the trace mode and 
trace range. "Storage Size" shows the 
number of cycles since the program 
began or since it was resumed. 

ENTER; 

EV ST=MR,A=2000,D=55 

EVENT 

Sets an event (EV) for a memory read 
at address (A =) 2000H with data (D =) 
of 55H. 



NOW LET'S EMULATE! 

TTfc Til 11 IT'i A 


BtBa&ftunins ^oispicty ea 

Hardware B>) and displays the status 
of the registers. 

ENTER: H D 

a RETURN, and then press the 
space bar several times. 

HISTORY 

Displays the contents of the real-time 
trace buffer. 

Remember this? This action causes 
the scrolling on the screen to stop 
and start. 

PRESS: ESC key. 


Exits the routine and brings the 
prompt back up on the screen. 

ENTER: D 2000 

DUMP 

Displays memory location 2000H. 
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COMMAND 

ACTION DEMONSTRATED COMMENT 


ENTER: B/B 

OFF 

BREAK 

Turns breakpoint (B) OFE 

ENTER: H 

EM 

HISTORY 

Changes to the End Monitor (EM) 
trigger mode. 

ENTER: H 


HISTORY 

Displays the status of the real-time 
trace buffer. Compare with the 
display below: 

Clock Counter = 00032059/204889 
Storage Mode = EM 

Storage Size = Full 

The word "Full’ 1 indicates a full 
buffer (2047 cycles). 

NOW LET’S CONTINUE EMULATION! 

ENTER: G 


GO 

Starts the program again and stops 
when hardware breakpoint A (display 

chnwc ^Rronlf Hnrrlwnro A'O nnr’iiro 

Now look at the address range 1000H- 
3000H— it should contain data of AA 
hex. Let’s find out! 

ENTER: D 

FF0X30 

DUMP 

Dumps a total of 30 bytes in word 
units. 

ENTER: D 

2FF0,3030 

DUMP 

Notice the difference from the 
previous command. 

ENTER: H 

D 100 

HISTORY 

Displays the last 100 locations in the 
real-time trace buffer. The space bar 
can be used to control the scrolling. 
Press the ESC key to exit. 

ENTER: H 

EE 

HISTORY 

Changes to the End Event (EE) trigger 
mode. 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: H 

HISTORY 

Displays the status of the real-time 
trace buffer. Compare with the 
display below: 

Clock Counter = 006405C/409692 

Storage Mode = EE 

Storage Size = Full 

ENTER: B/E ON 

BREAK 

Enables the event (E) breakpoint. 

ENTER: G 

GO 

Starts emulation again and stops 
when an event break (display shows 
< Break Event >) occurs. 

ENTER: H 

HISTORY 

Notice the status of the HISTORY 
command. Compare with the display 
below: 

Clock Counter = 000960C2/614594 
Storage Mode = EE 

Storage Size = Full 

ENTER: H D 60 

HISTORY 

Displays the last 60 pointers of the 
real-time trace buffer. Again, use the 
space bar to control the scrolling. 

Press the ESC key to exit. 

ENTER: EV 

EVENT 

Displays the status of the event set- 
tings again. 

ENTER: D 2000 

DUMP 

Memory location 2000 should contain 

55 hex. 

ENTER: G 

GO 

Starts emulation again and stops 
when hardware break A (display 
shows < Break Flardware A>) occurs. 

The address range 1000-7FFFH 
should now contain the data value 

55 hex. 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: D FF0,L30 

DUMP 

Dumps a total of 30 bytes in word 
units. 

ENTER: D 2FF0,L30 

DUMP 

Notice the difference from the 
previous command. 

ENTER: G 

GO 

Starts emulation again and stops 
when a user break occurs. 

THIS IS THE END OF EXAMPLE 1. 

THIS IS THE START OF EXAMPLE 2. 

ENTER: R RESET 

REGISTER 

Resets the registers. 

ENTER: Dl 0,30 

DISASSEMBLE 

Checks to see that the program is still 
around. 

ENTER: T A 

TRACE 

Traces all instructions to be 
displayed in a continuous manner. 

ENTER: G 

PRESS: The space bar to start 
and stop the display of the 
instructions. 

PRESS: The ESC key to exit. 

GO 

Starts emulation. 

ENTER: T J 

TRACE 

Traces all instructions but displays 
only Jump GP) instructions. 

ENTER: G 

PRESS: The ESC key to exit. 

GO 

Starts emulation. 

ENTER: T/S A 

TRACE 

Traces instructions by a single-step 
method (one instruction at a time). 
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COMMAND 

ACTION DEMONSTRATED COMMENT 

ENTER: T ICD displays: 

<ON> IS All 0000 -FFFF 

This shows that the trace is active, that 
the single-step trace feature is active 
(IS), that all instructions are to be 
traced and displayed, and that the 
trace range is 0000 to FFFF (the 
default). 

ENTER: G GO Starts emulation. 


PRESS: The space bar to control 
steps. 

PRESS: The ESC key to exit. 


THIS IS THE END OF EXAMPLE 2. 


THIS IS THE START OF EXAMPLE 3. 

This example will demonstrate other 
interesting features of the ICD. In this 
example, you will use different com- 
mands to MOVE, COMPARE, and 
SEARCH through memory, and also 
examine and change memory loca- 
tions. Other commands allow reading 
and modification of I/O ports. 

NOTE: During this example, the space 
bar and ESC key may be used to con- 
trol scrolling and to exit the display as 
shown in the previous examples. 

ENTER; R RESET REGISTER Resets the registers again. 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: F 2000,L10,00 

FILL 

Fills 16 bytes of memory with 00, 
starting at address 2000. 

ENTER: D 2000 

DUMP 

Displays the 16 bytes of memory just 
filled. 

ENTER: F 3000X10,11 

FILL 

Fills 16 bytes of memory with 11, start- 
ing at address 3000. 

ENTER: D 3000 

DUMP 

Displays the 16 bytes of memory just 
filled. 

ENTER: F 4000X10,22 

FILL 

Fills 16 bytes of memory with 22, start- 
ing at address 4000. 

ENTER: D 4000 

DUMP 

Displays the 16 bytes of memory just 
filled. 

ENTER: CO 2000X10,3000 

COMPARE 

Compares memory locations starting 
at 2000 with those at 3000 and 
displays the locations which are 
different. 

ENTER: S 4000X10,22 

SEARCH 

Searches and displays memory loca- 
tions which are equal to the searched 
data. 

ENTER: S/D 4000X10,22 

SEARCH 

Displays the locations which differ 
from the searched data. 

ENTER: M 2000X10,3000 

MOVE 

Moves a range of memory starting at 
location 2000 to address 3000. 

ENTER: D 3000X10 

DUMP 

Notice the difference from the 
previous command. 

ENTER: E 4000 

EXAMINE 

The ICD responds with 4000 22 = . 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: AA / 


Examines and changes location 4000. 
NOTE: The Slash (/) character terminates 
the response to the EXAMINE command. 

ENTER: P 0 

PORT 

Examines a port address and allows 
changes to be made. ICD responds 
with 0078 = . 

ENTER: A / 


Changes the port address. 

NOTE: The slash (/) character terminates 
the response to the PORT command. 



THIS IS THE END OF EXAMPLE 3. 



This concludes the examples which 
feature the ICD controlled by a ter- 
minal (no target system used). If you 
have a host computer available, you 
can now use it (through the ZICE soft- 
ware) to control the ICD. To find out 
how to connect your ICD to the host 
computer, see "How To Connect Your 

ICD To Other Devices” in Section 1. 



NOTE: The following exercise was 
tested with an IBM PC as the host 
computer. 



You are now operating in the REMOTE 
mode, where the ICD is controlled by 
a host computer. 

Execute the ZICE software 
program. 



PRESS: The RESET switch on the 
ICD. 


The ICD will respond with an identi- 
fication message and a prompt char- 
acter (>). 
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— 

ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: SA TEST.HEX,0,30,0 

SAVE 

Remember your test program? This 
just saved the program to your com- 
puter’s disk. 



Let's prove it! 

ENTER: ZD *.HEXorZD,H 


Displays all the files on the disk 
which end in .HEX. 

NOTE: ZD is the Z1CE command to 
display the directory of Z1CE files. 

Different versions of Z1CE may require 
a different command syntax. See your 

Z1CE documentation for the proper 
command format used with your 
particular ZICE version . 



Now reload the program (TEST. HEX) 
back to the ICD but at a different 
location. 

ENTER: L TEST.HEX.1000 

LOAD 

Downloads TEST.HEX to the ICD start- 
ing at address 1000H. The offset is 
optional. 

ENTER: Dl 1000,L30 

DISASSEMBLE 

Displays the program after complet- 
ing the download. 

ENTER: Q 

QUIT 

Ends the ZICE program and returns 
to the system DOS. 



THIS IS THE END OF EXERCISE 1. 
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Exercise 2: ICD Product Demonstration— Using The ICD With A Target System 

System Configuration: Host Computer Control Of The ICD 

Operation Mode: REMOTE 

ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

Execute the ZICE software 
program. 


THIS IS THE START OF EXERCISE 2. 

ENTER: 1 2 

IN-CIRCUIT 

Sets the mapping mode to target 
system memory only. 

ENTER: Dl 

DISASSEMBLE 

Disassembles user code. 

ENTER: G 

GO 

Now you're emulating! 

PRESS: The MONITOR break 
switch on top of the ICD to stop 
emulation. 



ENTER: H D 100 

HISTORY 

Displays your code that was executed 
right before the break. 

ENTER: 1 

IN-CIRCUIT 

This is the IN-CIRCUIT command. 

The following information describes 
the actions of this command. 



12: Full target emulation mode (target 
performs as usual except micropro- 
cessor is replaced by ICD). 

ENTER: 1 0 

IN-CIRCUIT 

10: No target emulation mode. (This 
mode does not require the use of any 
target resources. Used for software 
development when no hardware is 
available to execute code on. ICD 
depends on internal clock for oper- 
ation.) 
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COMMAND 

ACTION DEMONSTRATED COMMENT 

ENTER: I 1 IN-CIRCUIT II; Partial target emulation mode 

(median between 10 and 12 modes). 
Allows mapping of emulation 
memory to overlay portions of target 
memory. Also allows masking out of 
certain control pins on the micro- 
processor. 

THIS IS THE END OF EXAMPLE 1. 

THIS IS THE START OF EXAMPLE 2. 

This example will demonstrate the 
ability to execute part of memory out 
of the ICD and part out of the target 
system. In this example, you will move 
the target system’s ROM into the ICD's 
memory space and then execute it 
out of the ICD. 


STAY: In the In-circuit mode 11. 


Assume the following memory map: 



0 to 1FFF is ROM 

2000 to EFFF is RAM 

F0000 to FFFFF is No Memory 

ENTER: 1 1 

IN-CIRCUIT 

Sets the ICD to partial emulation 
mode. 

ENTER: MA 

MAP 

Displays the status of the MAP 
command. Notice that all the memory 
space of the Z80 defaults to being 
internal to the ICD. 


NOTE: The resolution of the MAP 
command is in increments of lK-byte 
blocks. 
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ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: MA 0,1FFF=RO 

MAP 

Maps to read-only instead of default 
read/write inside the ICD. 

ENTER: MA 2000,EFFF=US 

MAP 

Maps to user memory. 

ENTER: MA FOOO,FFFF=NO 

MAP 

Maps to non-existent memory. 

ENTER: MA 

MAP 

Notice the status of the MAP 
command. 



Now you can move the contents of the 
target ROM into the ICD. If you are 
using a host computer, you could now 
download a program to the ICD which 
was meant for the same address 
space as the target ROM. 

ENTER: M 0,1FFF,0.UP 

MOVE 

M means MOVE. O.IFFF is the target 
address, the second 0 is the ICD start 
address, UP means move user (target) 
memory to program (ICD) memory. 

ENTER: Dl 0,FFF 

DISASSEMBLE 

Shows the disassembled code of the 
target ROM residing inside of emula- 
tion memory. 



Now that the target ROM contents are 
in ICD memory, you can begin 
emulation. 

ENTER: R RESET 

REGISTER 

Resets the registers. 

ENTER: Dl 

DISASSEMBLE 

Shows the beginning of code. 
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Appendix B 


ACTION 

COMMAND 

DEMONSTRATED 

COMMENT 

ENTER: G 

GO 

Starts emulation. 



With the contents of the target ROM 
internal to the ICD, the code can now 
be modified using the in-line assem- 
bler, and then checked out for proper 
execution by setting breakpoints and 
using the real-time trace buffer, or 
simply tracing to the display. Once 
the new code has been checked, it 
can either be saved to a host com- 
puter or sent out the HOST/AUX 
port to a prom programmer for burn- 
ing a new prom. 



Now let's examine the PIN command. 

This command allows you to manipu- 
late certain control pins of the micro- 
processor in the 11 mode 

ENTER: 1 1 

IN-CIRCUIT 

Sets mapping to 11 mode. 

NOTE: The PIN command can only 
be used in the 11 mode. 

ENTER: PI 

PIN 

Displays the status of the PIN com- 
mand. Notice the pins that can be 
controlled. 

ENTER: PI INT=DI 

PIN 

Disables the interrupt pin to the 
emulation processor. 

ENTER: PI 

PIN 

Notice the difference from the 
previous status request. 



THIS IS THE END OF EXERCISE 2. 
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Appendix C 


Technical Specifications 



Emulated Processors/ 
Clock Speed 


Memory Size 

Mapping Resolution 

Real-time Trace Buffer 

Debugger Commands— built 
into the ICD 

Breakpoints 

Usable I/O Ports 

Communication Ports 

Baud Rates 

Physical Dimensions 

Probe Length 
Weight 

Power Requirements 

Power Consumption 

Operating Temperature 
Storage Temperature 
Humidity 


Z80/2.5 MHz 
Z80A/4 MHz 
Z80B/6 MHz 
Z80H/8 MHz 

64K bytes static RAM 

lK-byte blocks 

2K deep x 32 bits wide 


24 

4 hardware, 8 software 
256 

Two RS-232C/20mA current 
loop/TTL 

14 - 75 to 19,200bps 
(factory set at 9,600bps) 

300mm (1 1 ,8in) wide 
210mm (8.2in) deep 
80mm (3.2in) high 

510mm (20in) long 

3.3kg (7.31b) 

1 15VAC/230VAC; 50/60Hz 

40 watts 

0 C to 45 C 
- 10 C to 55 C 

30% to 85%; relative humidity 
(non-condensing) 
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Appendix C 


ICD Emulation Specifications 


Memory Area 

Program memory. The entire area of the program memory 
(64K bytes) is open. This memory is composed of high-speed 
static RAM. 


User memory. The entire 64K-byte memory space is available 
to the target system. 


Mapping. Both the program and user memory can be mapped 
in lK-byte blocks. The mapping modes include: user memory, 
emulation read/write memory, emulation read-only memory, 
and non-memory. 

I/O Port 

All 2S6 ports are open. 

Breakpoints 

4 hardware and 8 Software 


Hardware Breakpoints. A,B,C, and Event trigger. All hard- 
ware breakpoints can be individually enabled and disabled. 

A,B,C Breakpoint^. Address 16 bits, BHE. Each bit may be 
specified 0,1, or “don’t care.” Status may be specified: Op- 
code fetch, memory access, memory read, memory write, I/O 
access, I/O read, I/O write, and instruction execution. 


Event Trigger Breakpoint. Address 16 bits, BHE. Each bit may 
be specified 0, 1, or “don’t care.” Status may be specified as: 

OP code fetch, memory access, memory read, memory write, 

I/O access/read/write, and instruction execution. Data: 8 
bits, Each bit may loe specified 0,1, or "don’t care.” 


External Trigger Breakpoint. 1 channel— 1 TTL level specified 
at high or low edge of signal. 

1 
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Software Breakpoints. 8 points: 0 — 7. Any point may be 
specified as a software breakpoint by using the LDA, A or 
HALT instruction. All software breakpoints can be individually 
enabled and disabled. A break is caused in the target system 
when the CPU reads 7FH as an OP code (which represents an 
LDA, A instruction.) Execution of a software breakpoint does 
not effect the registers or flags. 

Real-time Trace Operation: The addresses, data, and status during emulation is 

stored in the real-time trace buffer. 

Trace capacity: 2K deep x 32 bits wide. 

Fixed trace data: AO-15, DO-7, MREQ*IORQ, RD«WR, Ml. 

Trigger functions include: End Monitor, Begin Monitor, End 
Event, Begin Event, Center Event, and Multiple Event. 



Appendix P 


Technical Bulletins & 
Application Notes 

Introduction 


Technical Bulletins 

Application Notes 


Things are constantly changing in the microprocessor indus- 
try, and ZAX wants! to help you stay on top of these changes. 
New products, emulation methods, and applications axe always 
being devised and tested by us in an effort to provide you with 
the latest and most effective equipment possible. In the same 
manner, revising your existing equipment keeps it current with 
the latest ICD designs from ZAX. 

One of the best ways we have of keeping you up-to-date is by 
issuing Technical Bulletins and Application Notes. 

Technical Bulletins inform you of major changes or revisions to 
the equipment’s hardware or firmware. Usually they are the 
result of a problem that's recently been solved, or they could 
be a feature that's been revised to improve the performance of 
the emulator. 

Application Notes are the result of new methods or procedures 
derived from emulation practices. They may also caution you 
against doing something a certain way, or they may show you a 
new way of accomplishing an old task. 

Both Technical Bulletins and Application Notes are sent to you 
as soon as they become available— you should never need to 
request them. When you receive your documents, insert them 
into this appendix for easy reference. That’s all there is to it! 
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GLOSSARY 


address 

A character or group of characters (such as a label, name, or 
number) that identifies a register, location, or unit where infor- 
mation is stored. 

allocate 

To assign blocks of data to specified blocks of storage. 

argument 

An independent variable upon whose value the value of a 
function depends. Usually the arguments of a function are 
listed in parentheses (sometimes within brackets) after the 
function name, if a function name is used. 

ASCII 

[ask-ee] American Standard Code for Information Interchange. 

A standard 8-bit information code used for information inter- 
change between equipments of different manufacturers. 

assemble 

To prepare an object language program from a symbolic lan- 
guage program by substituting machine operation codes for 
symbolic operation codes and absolute or relocatable ad- 
dresses for symbolic addresses. [With ZAX ICD-series emula- 
tors, this operation is performed using the ASSEMBLE com- 
mand.] 

assembler 

A computer program which operates on symbolic input data to 
produce machine instructions. An assembler generally trans- 
lates input symbolic codes into machine instructions— item for 
item— and produces the same number of instructions or con- 
stants which were defined in the input symbolic codes. 

baud rate 

The number of bits that are transmitted per unit of time 
(seconds). By definition, a baud is the reciprocal of time— in 
seconds— occupied by the shortest element of the code being 
transmitted, e.g., if the duration of the shortest signal element 
is 20 milliseconds, the modulation rate of the code is 50 bauds 
(per second). [ZAX ICD-series emulators can transmit up to 
19,200 bits per second.] 

bi-directional data bus 

A data bus in which digital information is transferred in either 
direction, thus saving time and providing easy access to stored 
information, 
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binary 

A numbering system based on 2's rather than 10's in which 
only the digits 0 and 1 are written. 

bit 

A bmary digit. 

branch 

To depart from the normal sequence of executing instructions 
in the computer. (Synonymous with a jump.) 

breakpoint 

A point in a program as specified by an instruction where the 
program may be interrupted by some external intervention or 
by a monitor routine. This program break permits a visual 
check, print out, or other analysis of the program before 
resuming with the normal sequence. Used extensively in de- 
bugging operations. [With ZAX ICD-series emulators, there are 

4 hardware and 8 software breakpoints available using the 

BREAK command.] 

buffer 

A storage device in which data is assembled temporarily 
during data transfers. It is used to compensate for the differ- 
ences in the rate of flow of information when transferring infor- 
mation from one device to another. 

byte 

A sequence of adjacent binary digits operated upon as a unit 
and usually shorter than a computer word. 

C 

A high-level programming language designed to optimize run 
time, size, and efficiency. It was developed as the systems pro- 
gramming language of the UNIX operating system on the PDP 

11/70 minicomputer from Digital Equipment Corporation. 

CLK 

clock 

clock 

Devices or units which control the timing of bits sent in a data 
stream, and controls the timing of the sampling of bits received 
in a data stream. One such clock device is a real-time clock, 
which measures the past or used time on the same scale as the 
external events it will be used to describe. Most microproces- 
sor clocks operate in the range of 1 to 12 MHz. 
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code 

A group of symbols that represent data or instructions in a 
computer. Digital codes may represent numbers, letters of the 
alphabet, control signals, etc. as a group of separate bits rather 
than continuous signals. (See microcode.) 

compiler 

A computer program, more powerful than an assembler, that 
will convert a higher level language into machine language. 

computer control of the ICD 

A remote code in which the ICD’s input/output is controlled by 
a host computer using a utility software program designed for 
that computer. In this mode, the host computer sends com- 
mands and receives data via an RS-232C interface. 

controller 

A device which interfaces a peripheral to a computer in order 
to relieve the processor of device-controlled responsibilities. 

CPU 

Central Processing Unit. The module within a computer that is 
responsible for fetching, decoding, and executing instructions. 

It contains a main storage unit, arithmetic unit, and special 
register groups. 

cross assembler or cross 
program 

A program run on one computer for the purpose of translating 
instructions from a different computer. 

cross compiling/assembling 

A method in which an existing computer can be used to write 
and debug what will become a microcomputer program. The 
advantage to cross compiling/assembling is that designers 
can have access to all of the conventional peripherals so that 
the object code produced during development can then be 
loaded into the microcomputer system. 

CRT 

Cathode Ray Tube. A television tube used to display alpha- 
numeric characters and graphics. 

DCE 

Data Communications Equipment. Refers to devices used for 
the transmission of information from one point to another. 
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debugging A process of eliminating "bugs" in a system by isolating and 
correcting all malfunctions and/or mistakes in a piece of 
equipment or a program of operations. 

decimal, binary-coded Describing a decimal notation in which the individual decimal 

digits are represented by a pattern of ones and zeros, e.g., in 
the 8-4-2-1 coded decimal notation, the number 12 is repre- 
sented as 0001 and 0010 for 1 and 2. This contrasts with a 
straight binary notation where 12 is represented as 1100. 

default value The choice among exclusive alternatives made by the system 
when no choice is made by the user. 

development system A system of devices, usually consisting of a diagnostic tool 

(such as an emulator), a computer, a printer, etc., that can be 
used together to develop and debug hardware (and software) 
for a given microprocessor. 

development tools Hardware and software devices that are used to develop and 

debug programs and/or microprocessor systems. 

DIP Dual In-Line Package. A standard IC package with two rows of 
pins at 0.1 " intervals. 

DIP switches A collection of small switches on a DIP that are used to select 
options on circuit boards without having to modify the 
hardware. 

disassembly Refers to a program that translates from machine language to 
(disassembler) assembly language. Usually used to decipher existing ma- 
chine language programs by generating symbolic code list- 
ings of a program. 

don’t care A term applied to an operation which can be changed or inter- 

rupted upon receipt of a control signal. The output of the oper- 
ation is independent of the input. 
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downloading 

A process whereby a file is loaded (using the LOAD com- 
mand) "down" to the ICD from the host computer system. 

DTE 

Data Terminal Equipment. Equipment comprised of a data 
source (transmitter) or data sink (receiver) that provides for the 
communication control functions (protocol). [ZAX ICD-series 
emulators use the DCE/ DTE select switch to control the com- 
munications output for the HOST/AJJX port.] 

dump 

The process of transferring the contents of memory at a given 
instant of time onto a screen for viewing, or outputting the 
memory contents to a hard copy device (such as a printer). 

[ZAX ICD-series emulators use the DUMP command to display 
the memory contents in either Hex or ASCII display. ] 

duplex 

A simultaneous two-way independent transmmission. 

dynamic RAM 

Memory that requires constant refreshing in order to store 
memory. 

EAROM 

Electronically Alterable Read Only Memory. A specialized 
random access read/write memory with a special slow write 
cycle and a much faster read cycle. 

echo check 

An accuracy check of a transmission in which the transmitted 
information received by an output device is returned to the 
information source and compared with the original informa- 
tion. 

editor 

A general-purpose text editing program that allows entry and 
maintenance of text in a computer system. The original text is 
entered and held in memory where it can then be changed 
and corrected by inserting, deleting, or changing lines of text 
or characters within a line. 

EEPROM 

Electronically Erasable Programmable Read Only Memory. 

An EEPROM is a device that can be erased electrically in one 
second and reprogrammed up to a million times. 
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EEPROM programmer 

A unit that provides a means of programming a single 

EEPROM or an EEPROM module from a terminal. 

EIA-RS-232C 

A standard method adopted by the Electronic Industries Asso- 
ciation to ensure uniform interface between data communica- 
tions equipment and data processing terminal equipment. [All 

ZAX ICD-series emulators use the E1A-RS-232C standard inter- 
face.] 

emulation 

Techniques using software or microprogramming in which one 
system is made to behave exactly like another system, i.e., the 
emulating system executes programs in the native machine- 
language code of the emulated system. 

emulation mode 

The mode that the ICD assumes in order to execute instruc- 
tions. 

emulator 

An instrument that imitates the control memory of future hard- 
ware. Also a device that causes a system (such as the target 
hardware) to accept certain software programs and routines 
and appear as if it were the other system. 

emulator, stand-alone 

An emulator whose execution is not controlled by a control 
program. It also does not share system resources with other 
programs, and excludes all other jobs from the computing 
system when it is being executed. [All ZAX ICD-series emula- 
tors can operate as stand-alone or as program-controlled (by a 
host computer) devices.] 

EPROM 

Erasable Programmable Read Only Memory. A specific type 
of ROM that can be programmed electrically. It can retain data 
even with the power disconnected but can be erased by ex- 
posure to short wavelength ultraviolet light, and may be re- 
programmed many times thereafter. Other types of EPROMs 
may be electrically erased. (See EEPROM.) 

field 

A set of one or more characters which is treated as a whole. 
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firmware 

Programs that are stored in a physical device (e.g. ROM) that 
can form part of a system or machine. 

FORTRAN 

FORmula TRANslator. A high-level language developed by the 

IBM Corporation, originally conceived for use on scientific 
problems but now used for many commercial applications as 
well. It requires the use of a compiler. 

full duplex 

A mode of communication in which data can be transmitted 
and received simultaneously. 

gate 

A device that has one output channel and one or more input 
channels such that the condition of the output state is deter- 
mined by the state of the input channel. The NAND, NOR, AND, 

OR, XOR, and NOT functions are examples of gates. 

GND 

Ground 

half-duplex 

A mode of communication in which data may be transmitted in 
only one direction at a time. 

halt 

A condition which occurs when an operation in a program 
stops. 

handshaking 

A sequence of signals that are required for communication 
between different systems. 

hardware 

Physical (electrical, electronic, or mechanical) equipment— as 
opposed to a computer program— used for processing data. 
Contrast with software. In the development environment, hard- 
ware is the equivalent of your target system. 

hex, hexadecimal 

Pertaining to a number system with a base of 16. The digits 0 
through 9 are used, then A through F, to represent decimal 
numbers 0 through 15, e.g., "FF” represents "11111111” binary, 
and "OA" is "00001010” binary. 
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PROM programmer 

A module or external device used to program programmable 
read-only memories. 

PROM programming 

The process of altering PROMs (called "burning"), either by 
blowing (melting or vaporizing) fusible links in bipolar PROMs 
or by storing a charge on the floating gates of UVEPROMs. 

RAM 

Random Access Memory. This type of memory is random 
because it provides access to any storage location point in the 
memory by means of horizontal and vertical coordinates. Infor- 
mation can then be "written" in or "read” out very quickly. 

read-only (RO) 

Refers to a process where information can be read from 
memory only. 

read-write (RW) 

Refers to a process where information can be read from and 
written into memory. 

real time 

Pertains to the actual time during which a physical process 
transpires. In emulation, real-time operation is very important 
because of the necessity for the emulator to maintain a "trans- 
parent” condition with regard to the device being emulated. 

[All ZAX emulators are capable of real-time emulation with no 
wait-states introduced for accessing memory.] 

register 

A memory device capable of containing one or more com- 
puter bits or words to facilitate arithmetical, logical, or transfer- 
ral operations, 

ROM 

Read Only Memory. A special memory that can be read into 
but not written into. 

RS-232C 

See EIA-RS-232C. 

semantics 

The relationship between symbols and their intended mean- 
ings independent of their interpretation. 
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journaling 

Refers to a process where all information generated in an 
emulation session on a host computer is output to a storage file. 

The entire session can then be reviewed, line for line, just as it 
was initially entered. 

kilobaud 

Refers to the number of one thousand bits per second. [ZAX 
ICD-series emulators are capable of transmitting at speeds to 

19.2 kilobauds.] 

linking loader 

A loader used to link compiled/assembled programs, rou- 
tines, and subroutines, and turn the results into operations. 

loader 

A program required on practically all systems that load the 
user's program along with system routines into the central 
processor for execution. Loaders transfer the object code from 
some external medium (tape or disk) into RAM. 

logic state analyzer (LSA) 

A device that monitors a system or component board and dis- 
plays the resulting information. 

machine cycle 

The time interval in which a computer (or similar device) can 
perform a given number of operations. 

machine language 

A set of symbols, characters, or signs, and the rules for com- 
bining them, that conveys instructions or information to a com- 
puter. 

macro 

Pertains to a specific type of instruction in assembly language 
that is implemented in machine language by more than one 
machine-language instruction, e.g., a group of instructions 
often designed to serve as an additive command or group of 
commands. 

macro assembler 

An assembler that is capable of assembling object programs 
from source programs written in symbolic language. 

macro instruction 

An instruction which stands for a predefined sequence of 
other instructions, called the "body" of the macro. Whenever 
a macro instruction is encountered in program text, it is "ex- 
panded," i.e„ replaced by its body. 
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mainframe, main frame 

Usually refers to large-scale computers (as opposed to micro- 
computers, microprocessors, and minicomputers). May also 
mean the fundamental portion of a computer, i.e., the portion 
that contains the CPU and controller units within the computer 
system. 

microcode 

A set of control functions performed by the instruction decod- 
ing and execution logic of a computer system. The microcode 
defines the instruction set of a specific computer. 

mnemonic code 

Refers to techniques used to assist human memory. A mne- 
monic code resembles the original word and is usually easy to 
remember, e.g., mpy for multiply, acc for accumulator. 

monitor mode 

Refers to a process where monitor commands from the ICD 
are executed. Dump, Fill, Disassemble, and Examine are all 
examples of commands used in the monitor code. 

MOS 

Metal-Oxide Semiconductor. A technology used for fabricat- 
ing high-density ICs. The name refers to the three layers used 
in forming the gate structure of a field-effect transistor. 

NOP, NOOP 

No-OPeration. An instruction used to force a delay of one 
instruction cycle without changing the status flags or the con- 
tents of the registers. 

object code 

The code produced by a compiler or special assembler which 
can be executed by the processor when it is loaded, as with 
most microcodes, or it may require a linkage phase prior to 
loading and execution. 

object program library 

An organized set of computer programs, routines, or common 
or specifically designed software, containing various pro- 
grams or routines, source or object programs, classified for 
intelligence or retrieval. 
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operating system Software that is required to manage the hardware and logical 
resources of a computer system. Also a part of a software 
package (program or routine) dedicated to simplifying input/ 
output procedures, sort-merge generators, data-conversion 
routines, or tests. 

operation code The symbols that designate a basic computer operation to be 
performed. This can be a combination of bits specifying an 
absolute machine-language operator, or the symbolic repre- 
sentation of the machine-language operator. 

P 

operator A symbol in programming language that represents an opera- 
tion to be performed on one or more commands (e.g., "add x”). 

parameter A constant or variat le in an equation or statement that may be 

assigned an arbitrary value, 

parity bit A redundant bit added to a group of bits so that an inaccurate 
retrieval of that group of bits is detected. 

Pascal A language designed to teach programming and the elements 

of computer science. Based on the language, ALGOL, it em- 
phasizes aspects of], structured programming. 

peripheral devices Various kinds of machines or devices that operate in combin- 
ation with a computer but are not physically part of the com- 
puter. Peripheral devices typically display computer data, 
store data from the computer and return it to the computer on 
demand, prepare aata for human use, or acquire data from a 
source and convert! it to a form usable by a computer. 

PIO interface Abbreviation for Par allel Input-Output interface. PIO interfaces 
allow the computer to input and output parallel data to and 
from an external par allel device such as a keyboard or printer. 
Parallel means that all the data bits output at the same time. 

PROM Programmable Redd Only Memory. A ROM that may be 
altered by the user. Some PROMs can be erased and repro- 
grammed through special physical processes. 
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high-level language 

Any group of computer languages which use symbols and 
command statements an operator can read. High-level lan- 
guages allow a user to write in a familiar notation rather than 
the machine-code language of a computer. BASIC, FORTRAN, 

FOCAL, and COBOL are all examples of high-level languages. 

host computer or host 
computer system 

The primary or controlling computer in a system operation. 

A host computer can also be reduced to a simple memory 
storage facility. [You can use a host computer to control your 

ICD's operation, or use it to store data files only. ZAX emulators 
work with a wide variety of host computers, from PCs to power- 
ful minicomputers.] 

ICE 

See in-circuit emulation. 

in-circuit emulation 

Hardware/software facilities for real-time I/O debugging of 
chips. With in-circuit emulation, the actual microprocessor is 
replaced by a connector (usually 40-pin type) whose signals 
are generated by an emulation program. The emulated micro- 
processor can be stopped, its registers examined or modified, 
etc. 

in-circuit probe 

The connector (typically a cable with connector ends) that 
plugs into the target system's processor socket at one end, and 
into the emulator at the other end. 

instruction 

A coded program step that tells the computer what to do for a 
single operation in a program. 

instruction set 

The basic set of instructions that a particular computer can 
perform. 

interface 

The physical connection between two systems or two devices. 

[ZAX ICD-series emulators interface to your target system for 
hardware development and debugging.] 

interrupt 

A break in the normal flow of a system or program that occurs 
in such a way that the flow can be resumed from that point at a 
later time. 


GLOSSARY 


source program 

stand-alone 

stand-alone system 

statement 

static RAM 

step 
stop bit 

symbolic debugging 


symbolic trace 


syntax 


target system 


in 


A program coded i 
that must be transit 

Pertains to a device 
to execute and conn; 


something other than machine language 
jted into machine language before use. 

that requires no other piece of equipment 
iplete its own operation. 


Usually, a microprocessor development system (MDS) that 
runs independent of the control of a computer. The MDS may 
contain a terminal and built-in display facility, which in effect 
makes it a full microcomputer with debugging capabilities. 

An instruction (mac jo) to the computer or other related device, 
to perform some sequence of operations. 


RAM that does not 
attention as long as 

One instruction in 4 


eed to be refreshed or receive any further 
power is applied. 


of 


The last element 
space immediately 
in accumulator storhi 


a character that defines the character 
|o the left of the most significant character 
ge. 


Symbolic commanc 
procedure. Symboli 
in source language! 
machine operation^ 
are independent o: 
addresses. 


computer routine. 


s that are used to assist in the debugging 
: refers to codes which express programs 
i.e., by referring to storage locations and 
by symbolic names and addresses that 
their hardware-determined names and 


A process where addresses in a program trace are replaced 
with symbols. The symbol conversion process is performed in 
the host system using the appropriate software program. 

Rules that govern sentence structure in a language, or state- 
ment structure in a language such as that of a compiler pro- 
gram. 

Refers to the processor under development. 
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trace 

Refers to the operation of the real-time trace buffer (storage 
facility) and its ability to capture and store a portion of the pro- 
gram memory area. 

transparency 

The ideal emulation condition in which the operation of the 
target system is uneffected when the emulator is substituted 
for the microprocessor. Transparency can be broken down 
into two categories: functional and electrical. To be function- 
ally transparent, the emulator should make no demands on 
any part of the target system’s resources such as interrupts and 
memory allocation. To be electrically transparent, the emula- 
tor should duplicate as closely as possible the microproces- 
sor's characteristics, such as timing and clock speed. 

trigger 

Refers to a user-specified reference point (external to the user 
program) which is used to determine where (and when) to 
begin and/or end a trace section. 

TTL 

Transistor Transistor Logic. A family of integrated circuit logic 
elements with a specific output structure, usually + 5-volt 
"ones” and 0-volt "zeros.” 

universal emulator 

A single emulator that is able to support several different 
processors. 

uploading 

A process whereby a file is transferred (using the "SAVE” 
command) from the ICD to the host computer system. 

virtual memory 

Refers to a technique that permits users to treat secondary 
memory (disk) storage as an extension of main memory and 
thus give the virtual appearance of a larger main memory. 

XON/XOFF 

Transmitter ON/OFF. 

ZICE 

Refers to the series of ZAX-developed support software pro- 
grams used to interface different host computer systems to 

ZAX ICD-series emulators. 
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